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(57) Abstract 

A system such as a video conferencing system, is provided which includes an image pickup device (14), an audio pickup device 
(12) and an audio source locator (10). The image pickup device (14) generates image signals representative of animage, while the audio 
oickUD device (12) generates audio signals representative of sound from audio source, such as speaking person. The audio source locator 
(10) processes the image signals and audio signals to determine a direction of the audio source relative to a reference point T*c system 
can further determine a location of the audio source relative to the reference point. The reference point can be a camera (14). The system 
can use the direction or location information to frame a proper camera shot which would include the audio source. 
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T.OCATING AN AUDIO SOURCE 
Background 

This invention relates to systems, including video 
conferencing systems, which determine a direction of an 
audio source relative to a reference point. 

Video conferencing systems are one variety of 
visual display systems and commonly include a camera, a 
number of microphones, and a display. Some video 
conferencing systems also include the capability to 
direct the camera toward a speaker and to frame 
appropriate camera shots. Typically, users of a video 
conferencing system direct the camera and frame 
appropriate shots . 

Summary 

In one general aspect, the invention features a 
system which includes an image pickup device, an audio 
pickup device, and an audio source locator. The image 
pickup device generates image signals representative of 
an image, while the audio pickup device generates audio 
signals representative of sound from an audio source. 
The audio source locator processes the image signals and 
audio signals to determine a direction of the audio 
source relative to a reference point. 

In another general aspect, the invention features 
a system including an image pickup device and a face 
detector. The image pickup device generates image 
signals representative of an image. The face detector 
processes the image signals to detect a region in the 
image having flesh tone colors, and determines, based on 
the detection, whether the image represents a face. 

In yet another general aspect, the invention 
features a video conferencing system including 
microphones, a camera, a positioning device, a processor, 
and a transmitter. The microphones generate audio 
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signals representative of sound from an audio source and 
the camera generates video signals representative of a 
video image. The positioning device is' capable of 
positioning the camera, for example, for tilting, 
5 panning, or zooming the camera. The processor processes 
the video signals and audio signals to determine a 
direction of a speaker relative to a reference point and 
supplies control signals to the positioning device for 
positioning the camera to include the speaker in the 

10 field of view of the camera, the control signals being - 
generated based on the determined direction of the 
speaker. The transmitter transmits audio and video 
signals, which can be the same as the audio and video 
signals used for locating the audio source, for video- 

15 conferencing. 

In another general aspect, the invention features 
a system including microphones, a camera, a positioning 
device, a processor, and a transmitter. The microphones 
generate audio signals representative of sound from an 

20 audio source and the camera generates video signals 

representative of a video image. The positioning device 
is capable of positioning the camera, for example, for 
tilting, panning, or zooming the camera. The processor 
processes the audio signals to determine a direction of a 

25 speaker relative to a reference point and supplies 

control signals to the positioning device for positioning 
the camera to include the speaker in the field of view of 
the camera, the control signals being generated based on 
the determined direction of the speaker. The transmitter 

30 transmits audio and video signals, which can be the same 
as the audio- and video signals used for locating the 
audio source, for video-conferencing. 
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Preferred embodiments may include one or more of 
the following features. 

The image pickup device includes a positioning 
device for positioning the image pickup device. The 
5 audio source locator supplies control signals to the 
positioning device for positioning the image pickup 
device based on the determined direction of the audio 
source. The positioning device can then pan, tilt, and 
optionally zoom the image pickup device in response to 
10 the control signals. The audio source locator supplies 
control signals to the positioning device for positioning 
the image pickup device. 

An integrated housing for an integrated video 
conferencing system incorporates the image pickup device, 
15 the audio pickup device, and the audio source locator, 

where the integrated housing is sized for being portable. 
In other embodiments, the housing can incorporate the 
microphones, the camera, the positioning device, the 
processor, and the transmitter. 
20 An image of a face of a person who may be speaking 

is detected in a frame of video. The image of the face 
is detected by identifying a region which has flesh tone 
colors in the frames of video and may represent a moving 
face which is determined, for example, by comparing the 
25 frame of video with a previous frame of video. It is 
then determined whether size of the region having flesh 
tone colors corresponds to a pre-selected size, the pre- 
selected size representing size of a pre-selected 
standard face. If the region having flesh tone .colors 
30 corresponds to a flesh tone colored non-human object, the 
region is determined not to correspond to an image of a 
face. The direction of the face relative to the 
reference point is also determined. 

The audio source locator includes an audio based 
35 locator for determining an audio based direction of the 
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audio source based on the audio signals and a video based 
locator for determining a video based lpcation of an 
image in one of the frames of video. The image may be 
the image of the audio source which may be an object or a 
5 face of a speaking person. The audio source locator then 
determines the direction of the audio source relative to 
the reference point based on the audio based direction 
and the video based location. 

The audio source locator detects the image of . the 
10 face of a speaking person by detecting a speaking person 
based on the audio signals, detecting images of the faces 
of a plurality of persons based on the video signals, and 
correlating the detected images to the speaking person to 
detect the image of the face of the speaking person. 
15 The audio source locator determines an offset of 

the video based location of the image from a 
predetermined reference point in a frame of video and 
modifies the audio based direction, based on the offset, 
to determine the direction of the audio source relative 
to the reference point. In this manner, the audio source 
locator can, for example, correct for errors in 
determining the direction of the audio source because of 
mechanical misalignments in components of the system. 

The audio source locator uses a previously 
determined offset of a video based location of an image 
in a previous frame of video and modifies the audio based 
direction to determine the direction of the audio source. 
In this manner, the audio source locator can, for 
example, prevent future errors in determining the 
30 direction of the audio source because of mechanical 
misalignments in components of the system. 

The audio source locator detects movements of a 
speaker and, in response to those movements, causes an 
increase in the field of view of the image pickup device. 
In this manner, audio source locator can, for example, 
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provide for the image pickup device capturing a shot of 
the person as the person moves without necessarily moving 
the image pickup device to follow the person. 

Audio source locator correlates the audio based 
5 direction detected based on the audio signals to the 
stored video based location of the image in a frame of 
video and modifies the audio based direction, based on 
the results of the correlation, to modify audio based 
direction to determine the direction of the audio source 
10 relative to the reference point. To do so, for example, 
audio source locator modifies its processing to improve 
its accuracy. 

A memory unit stores a previously determined 
direction of an audio source based on the audio signals 
15 and a previously determined video based location of an 

image of a face of a non- speaker person in a previous one 
of the frames of video. The audio source locator uses 
the stored audio based direction and video based location, 
to cause an adjustment in the field of view of the image 
2 0 pickup device to include, in the field of view, the audio 
source and the previously determined video based 
location. In this manner, the audio source locator can, 
for example, provide for room shots which include both 
speaking persons and nonspeaking persons . 
2 5 The audio based locator detects a plurality of 

audio sources and uses at least one parameter to 
determine whether to validate at least one of the 
plurality of audio sources to use in producing the 
control signals for the image pickup device, where 
30 changing the parameter in one direction increases a 

likelihood of the audio based locator validating at least 
one of the plurality of audio sources and changing that 
parameter in another direction decreases the likelihood 
of validating at least one of the plurality of audio 
35 sources. The audio source locator correlates the audio 
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based direction of the audio source with the stored video 
based location of the image in the some, frame to 
determine whether the image in that video frame 
corresponds to the audio source. If the image in the 
5 that frame of video corresponds to the audio source, the 
audio based locator changes the parameter in the 
direction which increases the likelihood of validation. 
If the image does not correspond to the audio source, the 
audio based locator changes the parameter in the 
10 direction which decreases the likelihood of validation. 
In this manner, for example, the response time of the 
audio source locator is dynamically monitored and 
improved . 

The audio source locator correlates the audio 

15 based direction of the audio source with the video based 
location of the image in a frame of video to determine 
whether the image corresponds to the audio source. If 
the audio source locator determines that the image fails 
to correspond to the audio source, the audio source 

20 locator causes an adjustment in the field of view of the 
image pickup device to include, in the field of view, the 
audio source and the video based location of the image in 
the frame of video. In this manner, for example, the 
audio source locator can allow for preventing gross 

25 camera pointing errors . 

The audio source locator can also determine the 
distance from the reference point to the audio source. 
The audio based locator determines a distance from the 
reference point to the audio source based on the audio 

30 signals while the video based locator determines another 
distance from the reference point to the audio source 
based on an image associated with audio source. Audio 
source locator then determines a finalized distance based 
on the audio based distance and the video based distance. 
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In some embodiments, the video based locator 
determines a video based location of the image by 
detecting a region representing a moving person and 
determining, in part or in whole, a contour of an image 
5 of the moving person. The video based locator uses a 
parameter in detecting the contour of the image, where 
changing the parameter in one direction increases a 
likelihood of detecting contours of images and changing 
that parameter in another direction decreases the 
10 likelihood. The video based locator changes the 

parameter, when detecting the contour of the image, to 
increase or decrease the likelihood. For example, the 
video based locator determines a noise level where an 
increase in the noise level decreases the likelihood of 
15 detecting contours representative of the persons in a 
video image and the, video based locator changes the 
parameter based on the noise level. For example, for a 
high noise level, the video based locator changes the 
parameter so as to increase the likelihood of detecting 
20 contours of images. In these embodiments, the audio 
source locator supplies control signals to the 
positioning device for positioning the image pickup 
device. The control signals include signals, based on 
the audio based direction detected based on the audio 
25 signals, for causing the positioning device to pan the 

image pickup device and signals, based on the video based 
location detected based on video, for tilting the image 
pickup device. 

Embodiments of the invention include one or more 

30 of these advantages. 

Determining the direction and/or location of an 
audio source relative to a reference point based on both 
audio and video provides for a system of checks and 
balances improving the overall performance of the 

3 5 automatic camera pointing system. 
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A low complexity and scaleable combination of 
common image processing blocks can be used to implement 
embodiments of the invention. Such embodiments can 
advantageously have low computational and memory 
5 requirements and at the same time deliver robust 
performance for various applications, such as video 
conferencing . 

Various types of errors in some visual systems, 
such as video conferencing systems, which locate speakers 

10 based on audio signals can be corrected for and possibly 
prevented. The corrected for errors include mechanical 
pan and tilt misalignment errors, range measurement and 
associated zoom errors, and gross pointing errors. The 
errors which can be prevented include gross pointing 

15 errors. Additionally, the response time of such visual 
systems can be decreased. 

In some embodiments, the performance of systems 
and algorithms for automatically setting up camera shots 
in such audio and visual systems are improved. For 

2 0 example, a better "room shot" can be obtained by 

including non-speaking persons detected based on video 
images. A moving speaker, such as one giving a 
presentation, can be tracked by tracking his image. 

Also, in some embodiments of video conferencing 

25 systems, it is impractical to provide for a microphone 
array to provide tilt information, for example, because 
of the desired cost or size of the system. In such 
embodiments, audio based locator can find the audio based 
direction of the audio source and cause the camera 

30 positioning device pan the camera. Video based locator 
can then detect an image of the speaker and cause the 
camera positioning device tilt the camera. In this 
manner, an already available resource in the system (that 
is, video signals) is used to provide an otherwise 

35 unavailable feature, tilt. 
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Embodiments of the invention include integrated 
and portable video conferencing units. In these units, 
video images can be used for providing " tilt information 
and possibly zoom information while the audio signals can 
5 be used for providing panning information. 

Additionally, audio based locators are typically 
less computationally intensive than video based locators. 
Therefore, it is faster to locate the speaker using audio 
based detection, to move an image pickup device based on 
10 the audio based detection, and then to use the results 
from the video based locator to correct the camera 
positioning and framing. 

Because the results from the audio based locator 
are not used by themselves but in combination with the 
15 video technology, embodiments of the audio based locator 
can be implemented using components which are not as 
precise as they may otherwise have to be. 

Brief Description of the Drawing 
Figure 1 shows an exemplary video conferencing 

20 system. 

Figure 2 schematically shows components of the 
video conferencing system. 

Figure 3 shows the various functional modules of a 
camera pointing module in the video conferencing system. 
25 Figure 4 is a flow chart of the operation of the 

camera pointing module. 

Figure 5 is a flow chart of detailed steps 
performed by a video face location* module. 

Figure 6 is the pseudocode for an algorithm for 
30 creating a flesh tone binary map. 

Figure 7 is the pseudocode for an algorithm for 
detecting pixels in a current video frame corresponding 
to objects which have moved since the previous video 
frame . 
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Figure 8 is the pseudocode for an algorithm for 
rejecting face segments based on their spatial luma 
variances and temporal luma difference variances. 

Figure 9 shows a flow chart of the steps taken by 
5 a face location tracking module. 

Figure 10 is the pseudocode for a prediction 
algorithm for estimating, for a current video frame, the 
location of the images of faces which were detected in a 
previous video frame. 
10 Figure 11 is the pseudocode for an association 

algorithm for associating the detected faces in the 
current video frame to existing track files. 

Figure 12 is the pseudocode for an algorithm for 
updating the track files. 
15 Figure 13 shows a flow chart of the steps taken by 

a speaker validation and framing module. 

Figure 14 illustrates an error in framing a camera 
shot due to a misalignment between the camera and a 
microphone array. 
20 Figure 15 shows a flow chart of the steps taken by 

a camera control module to correct for an error in 
framing a camera shot due to a misalignment between the 
camera and a microphone array. 

Figure 16 illustrates an error in framing a camera 
25 shot due to a gross pointing error. 

Figure 17 shows a flow chart of the steps taken by 
a camera control module to correct for a gross pointing 
error. 

Figure 18 illustrates an error in framing a camera 
30 shot due to a range finding error. 

Figure 19 shows a flow chart of the steps taken by 
a camera control module to correct for a range finding 
error. 
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Figure 20 shows a flow chart of the steps taken by 
a speaker validation and framing module to prevent gross 
pointing errors • 

Figure 21 shows a flow chart of the steps taken by 
5 a speaker validation and framing module to reduce the 
response time of the video conferencing system of Figure 
1. 

Figure 22 shows a flow chart of the steps taken by 
a speaker validation and framing module to frame a group 
10 shot. 

Figure 23A-C show top views of the position of a 
moving speaker relative to the field of view of a camera. 

Figure 24 shows a flow chart of the steps taken by 
a speaker validation and framing module to adjust the 
15 field of view of a camera for a moving speaker. 

Figure 25 shows an alternative embodiment of a 
video conferencing system. 

Figure 26 is a flow chart of detailed steps 
performed by a video face location module to detect 
20 contours of speaking persons. 

Description 

Figs. 1 schematically shows an exemplary video 
conferencing system 10. Video conferencing system 10 
includes a video camera 14 and an array of microphones 12 

25 which includes microphones 12A, 12B, 12C, 12D positioned 
a predetermined distance from one another in a 
predetermined geometry. Video camera 14 is mounted on, a 
camera positioning device 16 capable of panning, tilting, 
and zooming video camera 14 . 

30 Briefly, during operation, video conferencing 

system 10 receives sound waves from a human speaker and 
converts them to audio signals. Video conferencing 
system also captures video images of the speaker. Video 
conferencing system 10 uses the audio signals and video 
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images to determine a location of the speaker (s) relative 
to a reference point, for example, camera 14 or the 
center of rotation of camera positioning device 16. 
Based on that direction, video conferencing system 10 can 
5 then pan, tilt, or zoom in or out camera 14 to obtain a 
better image of the speaker (s) . 

Generally, a location of the speaker relative to 
camera 14 can be characterized by two values : a 
direction of the speaker relative to camera 14, which may 

10 be expressed by a vector, and a distance of the speaker 
from camera 14. As is readily apparent, the direction of 
the speaker relative to camera 14 can be used for 
pointing camera 14 toward the speaker by panning or 
tilting camera 14 and the distance of the speaker from 

15 camera 14 can be used for zooming camera 14 . . 

Fig. 2 schematically shows components of video 
conferencing system 10. Microphones 12 and camera 14 
respectively supply audio signals 22 and video signals 24 
to an audio and video signal processing unit 20. Audio 

20 and video signal processing unit 20 includes an audio 

source locator 28 which analyzes the audio signals 22 and 
video signals 24 to determine the location of a speaker. 
Audio source locator 28 supplies camera control signals 
26 to camera positioning device 16 and camera 14 for 

25 panning, tilting, and zooming camera 14. 

Audio and video signal processing unit 2 0 also: 
supplies a coder/decoder- -30- with audio signals 22 and — •- 
video signals 24. Coder/decoder 30 compresses the audio, 
and video signals and then supplies the compressed video 

3 0 signals and the audio signals to a network interface 40 
which transmits the signals across a telecommunication 
network 42 to a receiving video conference system (not 
shown) . A control and user interface layer 50 allows a 
user to interact with and control the operation of the 

35 various components of video conferencing system 10 
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including audio and video signal processing unit 20, 
coder/decoder 30 , and network interface, 40 . 

Fig. 3 shows the various functional modules of 
audio source locator 28. These modules can be 
5 implemented, for example, by an appropriately programmed 
processor such as a microprocessor having suitable 
memories such as read only memory (ROM) , random access 
memory (RAM) and/or other forms of memory. 
Alternatively, suitable processors for performing the 
10 functions of the modules in Fig. 3 include programmable 
digital signal processors, minicomputers, 
microcontrollers, programmable logic arrays and 
application specific integrated circuits. In other 
embodiments, some or all of the modules in Fig. 3 can be 
15 implemented to run on a processor which is not a part of 
video conferencing system 10. 

It should be noted that, in video conferencing 
system 10, the various components and circuits 
constituting video conferencing system 10 are housed 
2 0 within an integrated housing 10A shown in Fig. 1. 

Integrated housing 10A is designed to be able to house 
all of the components and circuits of video conferencing 
10. Additionally, integrated housing 10A can be sized to 
be readily portable by a person. In such an embodiment, 
25 the components and circuits can be designed to withstand 
being transported by a person and also to have "plug and 
play" capabilities so that video conferencing system can 
be installed and used in a new environment quickly. 

In some alternative embodiments, . microphone; array 
30 12, camera 14, camera positioning device 16, and audio 
source locator 2 8 may be separated from other components 
and included in an automatic camera positioning device. 
In such embodiments, a host video conferencing device 
incorporates the other components of video conferencing 
35 system 10. The automatic camera positioning device and 
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the host video conferencing device then together 
constitute a video conferencing system. 

Having described in general terms video 
conferencing system 10, the operation of audio source 
5 locator 28 of audio and video signal processor 20 will 
now be described in detail. An audio based locator (or 
audio based detector) 70 receives audio signals 22 and 
determines the location of a speaker (i.e an audio 
source) relative to the microphone array. Audio based 

10 locator 70 then generates a series of camera positioning 
directives with respect to panning, tilting, and zooming 
camera 14 . These directives can be partly based on face 
detection and location analysis performed by a video 
based locator (or video based detector module) 60. Audio 

15 based locator. 70 then supplies a camera control module 80 
with these camera positioning directives. After camera 
control module 80 moves camera 14 according to these 
camera positioning directives, video based locator 60 
analyzes the images in video frames 24 received as 

20 digital signals and stored as digital data in a memory 

storage unit (not shown) . Video based locator 60 detects 
human faces in the images and determines their position 
relative to a reference point in the frame of video in 
which they are detected. Camera control module 80 then 

25 correlates a detected video face with the detected audio 
speaker and uses that correlation to correct or prevent 

camera framing errors 

Fig. 4 is a flow chart of the operation of audio, 
source locator 28. Video based locator 60 includes 

30 processing modules 102-110, while audio based locator 70 
includes processing modules 112-118. Each of these 
processing modules will be described in detail below. 
Briefly, a video face location module 102 analyzes video 
signals 24 to detect faces in a single video frame. A 

35 video offset/error measurement module 104 measures the 
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offset of the location of the detected faces from some 
pre -determined and static reference point (for example, 
the center of the video image) and/or a dynamic reference 
point (for example, the currently detected speaker) . A 
5 face location tracking module 106 correlates the detected 
faces from the current video frame to the detected faces 
in the previous video frames and hence tracks the 
detected faces through a series of frames. This tracking 
allows for obtaining a proper position of a speaker in a 
10 video frame who may be moving, as will be described 

below. To perform this tracking, face location tracking 
module 106 creates and maintains a track file for each 
detected face . 



15 relative to a video coordinate system which is based on 
the video frame. The video coordinate system applies to 
each frame captured by camera 14 . The video coordinate 
system has a horizontal or x-axis and a vertical or y- 
axis. When determining a position of a pixel or an 

20 image, modules 102-108 determine that position relative 
the x-axis and the y-axis of that pixel's or image's 
video frame. Camera control module 80 and audio based 
locator 70 in turn use an audio coordinate system which 
indicates a location of a speaker based on pan, tilt, and 

2 5 zoom angles which describe the direction of the speaker 
relative to camera 14 and range or distance from camera 
14 to the speaker. A transform to audio coordinates 
module 108 converts coordinate measurements expressed in 
the video coordinate system to coordinate measurements 

30 expressed in the audio coordinate system using the pan, 
tilt, and zoom values of camera 14 when the frame was 
captured by camera 14 . Conversely a transform to video 
coordinates module 112 of audio based locator 70 converts 
coordinate measurements expressed in the audio coordinate 

35 system to coordinate measurements expressed in the video 



Modules 102-108 compute various measurements 
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coordinate system, also by using the pan and tilt values 
of camera 14 when the frame was captured by camera 14 . 

A face location memory module 110 stores in memory 
the results of the processing in modules 102-108, as will 
5 be described below. 

In audio based locator 70, audio speaker location 
module 114 determines the location of a speaker based on 
audio signals 22 . The results of this location 
determination is typically a set of pan, tilt, and range 

10 coordinate measurements. A speaker validation and 
framing module 116 determines whether the detected 
location of the speaker is a valid detection . Based on 
the results of the current and previous detections, 
speaker validation and framing module 116 then determines 

15 the most appropriate camera pan, tilt, and zoom (that is, 
the most appropriate camera shot or framing) . Speaker 
validation and framing module 116 can use the 
measurements obtained in video based locator 60 to 
improve the appropriate camera shot, as will be described 

20 below. An audio location memory 118 stores the results 
of the processing in modules 114-116. 

Camera control module 80 acquires from speaker 
validation and framing module 116 the desired camera 
framing directives. Camera control module 80 also 

25 acquires from video based locator 60 the offset and/or 

error measurements between the speaker locations detected 
based on the video signals and the audio signals. Camera 
control module 80 then uses the values acquired from 
video based locator 60 to adjust the desired camera 

30 framing acquired from audio based locator 70 to correct 
for mechanical misalignment errors, as will be described 
below in detail. 

The operation of various modules of video based 
locator 60 will now be described in detail. In video 

35 based locator 60, video face location module 102 analyzes 
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current and previous frames of video images from camera 
14 and determines the position of the faces in the 
current frame. Fig. 5 is a flow chart of the detailed 
steps performed by video face location module 102. 
5 Briefly, video face location module 102 identifies 

regions or segments in a frame which may contain a face 
based on detecting pixels which have flesh tone colors 
and which represent pixels which have moved. 

Video face location module 102 first retrieves 
10 current and previous video frames 132 which are stored in 
memory. In the described embodiment, video frames for 
face detection are captured in 420 YUV format at 3-5 
frames per second with a resolution of 320x240 pixels for 
luminance (luma) and 160x120 pixels for chrominance 
15 (chroma) . The luma values are then down sampled to a 
lower resolution of 160x120. Alternatively, QCIF video 
with a resolution of 172x144 for luma and chroma can be 
used. In other embodiments, other video formats, 
resolution, etc. can be used. 
20 Video face location module 102 then reduces, in 

step 134, the image in the retrieved frame to a flesh 
tone binary map, where each pixel that has a chroma value 
corresponding to flesh tone colors is assigned a value of 
"1" in the flesh tone binary map (hereinafter, referred 
25 to as a "flesh tone pixel"). Fig. 6 is the pseudocode 
for an algorithm 600 for creating^ tefete flesh tone binary 
map. For each pixel (step 605) , video face location 
module 102 tests the chroma value of the pixel against 
chroma threshold values for flesh tone colors. These 
30 chroma or flesh tone threshold values can, for example, 
be set at -50 < Cb < -5 and 7 < Cr < 60 . These values 
result in detecting a high percentage of flesh tone 
pixels irrespective of the skin tone or the lighting. 
. However, these threshold values also result in some 
35 falsely detected pixels which correspond to non-face 
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objects whose color falls within the flesh tone threshold 
values. If the chroma value of the pixel being tested 
falls within the flesh tone threshold values (step 610) , 
then video face location module 102 assigns a value of 
5 '1' to that pixel in the flesh tone map (step 615). If 
the chroma value of the pixel does not fall within the 
flesh tone threshold values (step 620) , then video face 
location module 102 assigns a value of '0' to that pixel 
in the flesh tone map (step 625) . 

10 Referring back to Fig. 5, video face location 

module 102 next analyzes, in step 136, the frame to 
detect which flesh tone pixels in the flesh tone binary 
map correspond to objects which have moved since the 
previous frame (hereinafter, "motion pixels") . A human 

15 face is usually moving. Therefore, by identifying pixels 
which do not correspond to moving objects, video face 
location module 102 rejects a high percentage of falsely 
detected flesh tone pixels. Pig. 7 is the pseudocode for 
an algorithm 700 for detecting motion pixels. For each 

20 pixel (step 705) , if the flesh tone binary map value for 
that pixel is '1' (step 710), then video face location 
module 102 determines whether the pixel is also a motion 
pixel. To do so, video face location module 102 tests 
the luma value of that pixel against the luma value of 

25 the same pixel in the previous frame. If the absolute 
difference of the luma values is less than to a motion 
threshold value (in the described embodiment, the value 
of the motion threshold value is 5 for an 8 bit luma), . -., 
then video face location module 102 determines that the 

30 pixel . corresponds to a non-moving object and reassigns 
the flesh tone binary map value for that pixel to '0' 
(steps 715-720) . 

Referring back to Fig. 5, after motion detection 
step 13 6, video face location module 102, in step 138, 
35 applies a filter to the flesh tone detection to reduce 
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false detections resulting from noise (step 138) . 
Various types of filters can be used for filtering out or 
reducing the effect of noise. In the described 
embodiment, video face location module 102 uses a linear 
5 two dimensional filter, namely a 5X5 box car filter with 
unity coefficients. Video face location module 102 
applies this filter to a particular pixel by adding the 
number of positive flesh tone and motion detections in a 
5X5 square of pixels surrounding the pixel being 
10 filtered. If the sum is above a pre -determined threshold 
value, then the flesh tone binary map value for that 
pixel is set to "1". Otherwise, video face location 
module 102 sets the flesh tone binary map value for that 
pixel to ' 0 ' . 

15 Video face location module 102 then, in step 140, 

segments the flesh tone binary image map into rectangle 
segments (or boxes) surrounding regions which contain 
contiguous areas of flesh tone pixels and therefore may 
contain images of faces (hereinafter, referred to as a 

20 "face segments") - To segment the image, , video face 
location module 102 scans each row of the flesh tone 
binary map to determine the start and end of each set of 
contiguous flesh tone pixels in the row where each pixel 
in a set has a chroma value close to the average chroma 

25 value for that entire set. When video face location 

module 102 finds such a set, video face location module 
102 determines the difference between the location and 
average chroma value of the set and the location and 
average chroma values of all the previously identified 

3 0 face segments in the current frame. Video face location 
module 102 then attaches the set of pixels to the face 
segment for which the calculated difference was within a 
predetermined threshold value and was also the minimum 
difference calculated for all previously identified face 

35 segments- Video face location module 102, if necessary, 
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adjusts the size of the face segment to include the new 
set of pixels. Additionally, video face location module 
102 recalculates the average chroma value for that face 
segment within the additional new set of pixels. Video 
5 face location module 102 in this manner assigns each 
flesh tone pixel to a face segment. If a set of pixels 
does not match a previously detected face segment, then 
video face location module 102 uses the set of pixels to 
create a new face segment . 
10 In segment/face classification step 142, video , 

face location module 102 then examines all of the 
detected face segments and rejects those face segments 
which do not likely represent a face. Video face 
location module 102 uses two methods to determine whether 
15 a face segment likely represents a face. According to 
the first method, video face location module 102 
determines whether the size of the face segment 
corresponds to a default size of the image of a typical 
or preselected standard head given the camera range 
20 value. If the size of a face segment is less than the 
default image size at that range (or a scaled default 
image size at that range, such as 125% of the default 
image size) , video face location module 102 determines 
that the face segment likely does not represent a face. 
25 Additionally, if the proportions of a face segment are 

not within a range for a typical head (for example, width 
to height ratio of 1.5), video face location module 102 
determines the face segment likely does not represent a 
face . . 
30 According to the second method, video face 

location module 102 rejects face segments which have been 
detected because of shadows moving over flesh tone 
colored backgrounds or because of objects moving over 
flesh tone colored background. To do this, briefly, 
35 video face location module 102 rejects face segments 
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having spatial lutna variance or temporal luma difference 
variance below predetermined threshold values. Fig. 8 is 
the pseudocode for an algorithm 800 for rejecting face 
segments based on spatial luma variance and temporal luma 
5 difference variance. 

Generally, movement of shadows over flesh tone 
colored stationary objects cause the pixels for the flesh 
tone colored stationary objects to be detected as flesh 
tone pixels and motion pixels. In these face segments, 
10 because of the movement of shadows, all luma values of 
the face pixels are generally reduced by the same amount 
from the corresponding luma values in the previous frame. 
Therefore, the temporal luma difference variance for a 
face segment between the current and the previous frame 
15 is relatively small. (The temporal luma difference 
variance of a face segment is the variance of the 
difference between the luma value of the pixel between 
the current and previous frames from a mean difference, 
between the current and previous frames, of all luma 
20 values for the pixels in that face segment.) In the case 
of most other moving objects which are not subject to 
shadows, the difference in the luma values varies 
significantly from the mean difference and hence the 
temporal luma difference variance is relatively large. 
25 Steps 805-825 in algorithm 800 in Fig. 8 use the 

temporal luma difference variance to detect face segments 
which have been classified as face segments but more 
likely represent stationary objects subject to moving . 
shadows. For each face segment (step 805), video face 
30 location module 102 calculates the mean difference in the 
luma values for that face segment between the current 
frame and the previous frame (step 810) . To do so, for 
each pixel in the face segment, video face location 
module 102 computes the difference in the luma values 
35 from the previous frame. Video face location module 102 
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then adds these differences and divides the sum by the 
size of the face segment to obtain the mean difference in 
luma values. Video face location module 102 then 
determines, for each pixel, the squared difference 
5 between the mean difference in luma values computed in 
step 810 and the difference in luma values between the 
current frame and the previous frame (step 815) . Video 
face location module 102 adds these squared differences 
and divides the sum by the size of the face segment to 

10 determine the temporal luma difference variance for the_ 
face segment (step 815) . If the temporal luma difference 
variance for the face segment is below a predetermined 
threshold value (step 820) , video face location module 
102 determines that the face segment is likely not an 

15 image of a face (step 825) . 

Additionally, as stated above, video face location 
module 102 uses spatial luma variances to reject face 
segments which represent uncovered, flesh- tone 
background. For example, when a person moves in front of 

20 a flesh tone colored door, video face location module 102 
identifies the trailing edge of the image of the person 
as moving pixels. Similarly, video face location module 
102 may identify hands which move over a flesh-colored 
table as moving pixels. To identify these false face 

2 5 segments, video face location module 102 uses the fact 
that uncovered flesh tone colored objects are typically 
smooth, while faces have multiple edges and are not 
smooth. Therefore, video face location module 102 
calculates the spatial luma variance* of each face segment 

30 and rejects the face segments which have variances less 
than a pre -determined threshold value. The spatial luma 
variance for a face segment is the sum of the squared 
differences between luma values for all pixels in a face 
segment from the mean luma value for that face segment 

35 divided by the size of the face segment. 
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Steps 805 and 830-845 in algorithm 800 in Fig. 8 
use the spatial luma variances for the detected face 
segments to reject false face segments which more likely 
represent flesh tone background. For each face segment 
5 (step 805) , video face location module 102 computes the 
mean luma value for that face segment (step 830) . To do 
so, video face location module 102 adds the luma values 
of all of the pixels in that face segment and divides the 
sum by the size of the face segment. Video face location 

10 module 102 then determines the sum of the squared 

differences of the luma value of each pixel in the face 
segment from the mean difference in luma values computed 
in step 830. Video face location module 102 divides the 
sum by the size of the face segment to determine the 

15 spatial luma variance of that face segment (step 835) . 

If the spatial luma variance of the face segment is below 
a predetermined threshold value (step 840), video face 
location module 102 determines the face segment being 
examined is not an image of a face (step 845) . 

20 At this point, video face location module 102 

assumes that all remaining face segments represent faces. 
After segment/face classification step 142, video face 
location module 102 reduces the flesh tone binary map to 
a map 144 having a number of face segments representing 

25 detected faces. 

Referring back to Fig. 4, after video face 
location module 102 finishes executing, video 
offset/error measurement module 104 determines the offset 
of detected faces in the camera view from., a video ; : - 

30 coordinate reference point. The reference point can be a 
fixed reference point (for example, the center of the 
camera image or a frame of video) or a dynamic reference 
point (for example, location of a speaker detected by 
audio based locator 70) . In either case, for each 

3 5 detected face, video offset/error measurement module 104 
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computes the offset by determining the X-axis and Y-axis 
difference between the center of the detected face and 
reference point . Where the reference point is a location 
of a speaker detected by audio based locator 70, audio 
5 based locator 70 first converts the coordinates of the 
reference point from the audio coordinate system to the 
video coordinate system (step 112) . Video offset/error 
measurement module 104 then uses these converted values 
to calculate the offset. 

10 After video offset/error measurement module 104, 

face location tracking module 106 is performed. 
Generally, face location tracking module 106 associates 
detected faces in the current frame (that is, currently 
detected faces) to previously detected faces in existing 

15 track files. Face location tracking module 106 then 

updates the existing track files. Face location tracking 
module 106 also creates new track files for those 
currently detected faces that can not be associated with 
existing track files. The results of face location 

20 tracking module 106 are typically used for framing camera 
shots in the cases where the video conferencing system 10 
moves camera 14 to track a moving speaker, as will be 
described below. 

Each track file corresponds _to one detected face 

25 and stores parameters for that face. The stored 

parameter values not only include those associated with 
the current video frame but also, if required, those 
associated with the previous video frames in which the 
face was detected. The parameters include location* 

30 size, and parameters associated with movement. The track 
files can also store the audio coordinate pan, tilt, and 
range values associated with detected faces for the 
particular frames in which the faces were detected. 
Additionally, the track files can store the values for 

35 the number of frames in which the face has been detected 
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(hereinafter, "update_count n ) and the number of frames 
since the last time the face was detected (hereinafter, 
"noupdate__co\int" ) . The track files also can store a 
confidence measurement of the accuracy of any estimated, 
or predicted location based on the values stored in the 
track file. 

Fig. 9 shows a flow chart 900 of the steps taken 
by face location tracking module 106. For each video 
frame processed for face detection (step 901) , face 
location tracking module 10 6 first determines whether the 
frame of video was captured at the start of a new camera 
move (step 902) - If so, face location tracking module 
106 initializes the initial set of track files (step 
905) . The initial set of track files can be either a set 
of new track files or all of the existing track files. 
Face location tracking module 106 determines which - 
initial set of track files to use based on. how the track 
files will be used. If the initial set of files includes, 
only new track files, then face location tracking module 
106 creates a new track file for each detected face in 
the current frame. These track files are then populated 
with the pan, tilt, and range values or audio location of 
the face and the parameters associated with the detected 
faces in the current frame such as video coordinates 
size, location, offset, motion, and other measurements 
from modules 104 (Fig. 4) , as needed. Face location 
tracking 106 does not use the video frame at the start of 
a new camera move for face tracking (step 93 0) and the 
face tracking processing for this video frame ends (step 
925) . 

If face location tracking module 106 determined 
that the video frame was captured at the start of a new 
camera move (step 902) , face location tracking module 106 
next determines whether the video frame was captured when 
a camera move was in progress (step 907). If a camera 
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move was in progress, face location tracking module 106 
does not use the video frame for face tracking processing 
(steps 907, 930) and the face tracking processing for 
this video frame ends (Btep 925) . 
5 If the video frame was captured when a camera move 

was not in progress, face location tracking module 106 in 
step 910 determines whether the camera was settled when 
the video frame was captured, that is, whether all camera 
movements which affect the video face location processing 
10 had stopped) . These movements include camera pan, tilt, 
zoom, auto-focus, auto-white balance, and auto - exposure . 
Face location tracking module 106 determines whether 
camera 14 had settled by either sampling camera settling 
signals 25 (Figs. 3 and 4) until the signals stop 
15 changing or by waiting for some pre -determined time 
period aftex, a camera move starts. 

If the video frame was captured when camera 14 had 
not settled, then face location tracking module 106 does 
not use the video frame in face location tracking (steps 
20 910, 930) and the face tracking processing for this video 
frame ends (step 925) . If face location tracking module 
106 determines that camera 14 had settled (step 910) , 
face location tracking module 106 attempts to associate 
the location of detected faces in the video frame with 
25 the existing track files (step 915) . (In the case where 
the existing track files are not used in step 905, face 
location tracking module 106 does not perform steps 915 
and 920.) Associating the location of the detected faces 
involves the following steps, described here in general 
30 terms: 

Propagation or prediction of position, confidence, 
and search bounds: In general terms, this step 
involves, based on the track files associated with 
the previous frame, predicting estimates of the 
35 locations in the current video frame of the faces 
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detected'in the previous video frame. This step 
also involves calculating a confidence value for 
that estimation. 

Ordered association of the current detected faces 
5 and the track files associated with the previous 

frame: In general terms, this step involves, for 
each track file, determining the likelihood that 
each currently detected faces corresponds to the 
track file. Face location tracking module 106 

10 then determines which of the detected faces passes 

a minimum threshold of likelihood and also has the 
highest measure of likelihood. Face location 
tracking module 106 then associates that detected 
face to the track file. 

15 - Deletion of old files based on the value of 

noupdate_count variable. 

Creation of new files for detected faces in the 
current frame not associated with existing track 
files. 



2 0 Each of these steps will now be described in 

detail. Fig. 10 is the pseudocode for a prediction 
algorithm 1000. In the described embodiment, face 
location tracking module 106 uses a fixed gain filter to 
predict the new values. In other embodiments face 

25 location tracking module 106 can use more complex filters 
such as variable gain filters as in Kalman filters. 

For all track files i (step 1005) , face location 
tracking module 106 predicts the horizontal or x- axis 
location of a pixel that represents the center of a 

30 detected face (hereinafter, the center pixel) 

corresponding to a track file (step 1010) . To compute 
the predicted value of the horizontal location of the 
center pixel (x* (n) ) , face location tracking module 106 
adds the estimated location of the center pixel in the 
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previous frame (Xifn-D) to the horizontal value of the 
estimated pixel motion associated with the previous frame 
(n-D) . (The unit of measurement used for the various 
motion variables is a unit of speed expressed in terms of 
5 number of pixels per video frame.) Face location 

tracking module 106 computes the predicted value of the 
pixel motion when updating the track files, as will be 
described below. In step 1015, face location tracking 
module 106 computes the predicted hori zonal value of the 

10 pixel motion associated with the current frame (ij (n) ) by- 
multiplying the horizontal value of the estimated pixel 
motion of the previous frame by a predetermined 

fixed gain value (sr^) . Face location tracking module 106 
then performs steps 1020 and 1025 which are similar to 

15 steps 1010 and 1015 and calculates the vertical axis (y- 
axis) values . In step 1030, face location tracking 
module 106 computes the value of the confidence parameter 
for the current prediction {t: ± (n) ) by multiplying the 
confidence value in the track file {c l (xi'l)) by a fixed 

20 gain value . 

After the prediction step, face location tracking 
module 10 6 attempts to associate the detected faces in 
the current video frame to the existing track files. 
Fig. 11 is the pseudocode for an association algorithm 

25 1100 for associating the detected faces in the current 

video frame to the existing track files. Generally, face 
location tracking module 106 compares each track file to 
all detected faces. Face location tracking module 106 
associates a detected face to a track file § - if the 

30 distance along the x- and y-axes between the position of 
the detected face and the predicted position of the face 
associated with that track file is smaller than the 
difference for all other detected faces. 

For each track file i (step 1105) , face location 

35 tracking module 106 determines whether the track file is 
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an initialized and active track file {step 1107) . If the 
track file is an initialized and active, track file, then 
face location tracking module 106 determines for each 
detected face j whether the distance along the x- and y- 
5 axes between the position of the detected face and 

predicted position values for the track file is less than 
the maximum distance threshold values (steps 1110-1112) . 

In the described embodiment, the maximum distance 
threshold values are statistical bounds based on two 
10 variances, measured in each of the x- and y-axes: 

variance of the position of a typical pixel from one 
frame to the next [a 2 „ and o*„) and the variance in the 
measurement of pixel locations in the current frame due 
to various errors in measurement i.o 2 m and a 2 yj . In the 
15 described embodiment, the statistical bound assumes that 
both variances have a constant value for a given camera 
zoom setting. However, in other embodiments, the 
variances may be unique for each frame based on previous 
measurements or based on input from sensors monitoring 
the operation of the equipment. The statistical bound is 
computed as three times the standard deviations 
calculated as the sum of each of the variances in each of 
the x- and y -axes: 



20 



2 2 



s Yl in) m *J a £y* a £n 



where Q 2 a is the horizontal position variance; a 2 „ is the 
25 vertical position variance; a 2 m is the horizontal 

measurement variance; and a 2 ^ is the vertical measurement 
variance . 
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If the distance between the detected face j and 
the predicted values for the track file are less than the 
maximum distance threshold values (steps 1112) , the 
detected face j is marked as a possible candidate for 
5 association with the track file (step 1115) . 

For all face candidates for associations with 
track file i in the current frame, face location tracking 
module 106 next attempts to find a candidate face that is 
closest to the predicted value for the track file (steps 

10 1117-1122) and selects that face for association with 
track file i. In step 1117, face location tracking 
module 106 first determines whether any of the detected 
faces were marked as a possible candidate for association 
with track file i. If so, for each such candidate j 

15 (step 1120) , face location tracking module 106 calculates 
the distance (d ±j ) between the center pixel of the 
detected face and the center pixel in the track file i 
(step 1122) . Face location tracking module 106 then 
finds the minimum of these calculated distances (d^) 

2 0 (step 1125) and marks the corresponding detected face as 
being associated to track file i (step 1127) . In step 
1130, face location tracking module 106 marks the track 
file as having been associated to a detected face in the 
current video frame and, in step 1132, resets the value 

25 of variable noupdate__count . Face location tracking 
module 106 then populates the track file i with the 
values associated with the matching detected face, namely 
the location of the center pixel (steps 1135-1137) and 
the dimensions of the detected face (steps 1140-1142) . 

30 If, in steps 1110-1115, face location tracking 

module 106 does not find any suitable candidates for 
association among the detected faces in the current video 
frame, face location tracking module 106 marks track file 
i as not having been associated to a detected face (step 
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1147) . Face location tracking module 106 then increments 
the variable noupdate_count (step 1150),. 

As stated above, after associating the detected 
faces to the track files, face location tracking module 
5 106 deletes track files which for more than a 

predetermined number of frames have not been associated 
with a detected face. Face location tracking module 106 
deletes a track file by marking the track file as not 
being initialized and resetting the variables in the 

10 track file. 

In some cases, after attempting to associate the 
detected faces with the existing track files, some 
detected faces in the current video frame remain as not 
associated with any existing track file. In that case, 

15 the values associated with the detected face are 

populated in a new track file. Additionally, the value 
of the confidence parameter (CiCn)) for the current frame 
is set to a predetermined value (for example, 0.5). 
Also, the horizontal and vertical pixel motion variables 

20 (^(n) and yi(n)) are set to a predetermined value (for 
example, zero) - 

Referring back to Fig. 9, at this point, face 
location tracking module 106 updates the various 
parameters in the track files based on whether a track 

25 file has been associated with a detected face in the 
current video frame (measurement update step 920) . 
Generally, each parameter is updated based on the value 
for that parameter in the current and previous frames, 
the predicted value for that parameter, and a gairi value 

30 that represents an estimate of errors due to various 
equipment imperfections. 

Fig. 12 is the pseudocode for an algorithm 1200 
for updating the track files. For each track file i 
which has been associated with a detected face in the 
35 current frame (step 1202) , face location tracking 
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measurement update module 920 updates a number of 
variables in the track file. In steps 1205-1207, face 
location tracking module 920 computes the horizontal and 
vertical center pixel values for the track file i (x ± (n) 
5 and y d (n) , respectively) . To determine these values, face 
location tracking module 920 first subtracts the 
corresponding predicted center pixel value (x £ (n) and 
y ± (n) ) from the center pixel value of the associated 
detected face measurement {x mj (n) and y nj (n) ) . The result 

10 is then multiplied by a gain value (gr p ) compensating for 
an expected average error due to various equipment 
defects. Face location tracking module 920 then adds the 
result of this multiplication to the corresponding 
predicted center pixel value (iq (n) and y x (n) ) . 

15 In steps 1210 and 1212, face location tracking 

module 92 0 computes the horizontal- and vertical pixel- 
motion values for the track file i (Xj (n) and y 4 (xi) , 
respectively) . To determine these values, face location 
tracking module 106 first subtracts the corresponding 

20 predicted pixel position value (kj^fn) and y ± (n)) from the 
horizontal and vertical center pixel values for the track 
file i (x, (n) and y ± (n) ) calculated in steps 1205-1207. 
The result is then multiplied by a gain value (grj 
compensating for an expected average error due to various 

25 equipment defects. Pace location tracking module 106 
then adds the result of this multiplication to the 
corresponding predicted pixel motion value to; and 
yi (n) ) . 

In steps 1215 and 1217, face location tracking 
3 0 module 106 computes the horizontal and vertical size 
values for the track file i (x el (n) and y 8i (n) , 
respectively) . To determine these values, face location 
tracking module 106 first subtracts the corresponding 
size value in the track file from the previous frame 
35 (x 8i (n-l) and y 8i (n-l)) from the size values for the 
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associated detected face (x 3j (n) and y 3j (n) ) . The result 
is then multiplied by a gain value (g a ) .compensating for 
an expected average error due to various equipment 
defects. Face location tracking module 106 then adds the 
5 result of this multiplication to the corresponding size 
value in the track file from the previous frame (n-1) 

and y Bi (n-1) ) . 

Face location tracking module 106 next calculates 
the confidence value for the values that now populate the 
10 track file (step 1220) . Face location tracking module. 

106 first subtracts the predicted confidence value (t ± (n)) 
from one and multiplies the result by a gain value (g c ) . 
Face location tracking module 106 then adds the result to 
the the estimated confidence value for the previous 

15 frame (c* (n-1) ) - 

Face location tracking module 106 then validates 
the track files in steps 1225-1232. Generally, face 
location tracking module 106 assumes a track file is 
invalid until it is validated. In step 1225, if a track 
20 file with which a face detection is associated is ..marked 
as invalid, face location tracking module 10 6 increments 
the value of the update_count variable (step 1227) . If 
the value of the update_count variable and the value of 
the confidence variable of- the track f ile are each 
25 greater than a corresponding threshold value required 
from a valid frame (step 1230) , then face location 
tracking module 106 validates the "track file by marking 
it as such (step 1232) . 

For each track file i which has not been. 
30 associated with a detected face in the current video 

frame (step 1235) , face location tracking module 106 also 
updates a number of variables in the track file. Face 
location tracking module 106 populates the horizontal and 
vertical center pixel values for the track file i (x x (n) 
3 5 and y x (n) f respectively) , the horizontal and vertical 



WO 99/60788 PCT/US99/10667 



pixel motion values for the track file i {k ± (n) and ¥ ± (n) , 
respectively), and the confidence variable {c ± (n)) with 
the predicted values (steps 1237-1245 and 1252) . Face 
location tracking module 106 sets the horizontal and 
5 vertical size values for the current video frame {x Bi (n) 
and y Bi (n) , respectively) with the values associated with 
the previous video frame in which the detected face 
measurements were updated. 

Referring back to Fig. 4, after face location 
10 tracking module 106, transform to audio coordinates 

module 108 converts the tracked location values to audio 
coordinate system . 

After transform to audio coordinates module 108, 
face location memory module 110 stores the values of the 
15 various parameters associated with the detected faces in 
the current video frame in files associated with the 
detected faces. Generally, face location memory module 
110 stores the result of the analysis in the previous 
modules for future access when the camera view may not 
2 0 contain a particular region of interest. Which of the 
results are stored depends on how the data will be used 
in the future. The stored data can include location and 
size of detected faces. Additionally, the stored data 
can be organized by unique numbers assigned to each face 
25 or by spatial sectors. The data also includes the 

results of face location tracking after being converted 
into the audio coordinate system. At this point, video 
based locator 60 finishes its analysis. 

Having described the operation of video based 
30 locator 60, the operation of the audio based locator 70 
will now be described. Audio speaker location module 114 
of audio based locator 70 detects the location of a 
speaker based on audio signals from microphone array 12. 
A method of locating a speaker based on audio signals 
35 from a plurality of microphones is described in detail in 
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the commonly assigned application, incorporated herein by- 
reference, entitled "Method and Apparatus for 
Localization of an Acoustic Source" , serial no. 
08/663 ,670, filed on June 14, 1996 (hereinafter, "the 
5 '670 application"). Briefly, the method in the '670 

application uses at least two microphones spaced from one 
another. According to the method in the ' 670 
application, generally, audio speaker location module 114 
processes the audio signals by determining whether 
10 signals acquired during a particular time frame represent 
the onset or beginning of a sequence of audio signals 
from the sound source. Audio speaker location module 114 
identifies received audio signals representative of the 
sequence of signals when the data represents the 
15 beginning of the sequence. Audio speaker location module 
114 then determines the location of the -source -based upon 
the received audio signals. 

The onset or beginning of a sequence of audio 
signals from the source is detected on a f requency-by- 
20 frequency basis. Data associated with those frequency 
components of acquired signals which satisfy the 
following two conditions are deemed to be representative 
of signals occurring at the onset of a sequence of audio 
signals from the source. First, the magnitude of the 
25 frequency component should preferably be greater than the 
background noise energy for that frequency by at least a 
predetermined amount. Second, the magnitude of the 
frequency component should preferably be greater, by at 
least a predetermined amount, than the magnitude of 
3 0 corresponding frequency component acquired during a 
predetermined number of preceding time frames. 

If the two conditions are met for a particular 
frequency component during a particular time frame, then 
it is assumed that an onset condition is met with respect 
3 5 to that frequency. A cross -spectrum for the audio 
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signals acquired by the pair of microphones during the 
time frame is generated with respect to. each such 
frequency component, and a cross -spectrum for the noise 
at each such frequency is subtracted to identify the 
5 audio received signals representative of the sequence of 
signals from the audio source. The audio cross -spectrum 
is accumulated during a predetermined length of time. If 
at the end of the predetermined time period, non-zero 
values for at least a specified number of frequencies 

10 have been accumulated, the accumulated cross -spectrum - 
values are then used to compute cross-correlation values. 
The cross -correlation values in turn are used to 
determine the time delay between signals arriving at the 
pair of microphones from the common source. These time 

15 delays are then used to determine the direction and 
bearing angle of the audio source with respect to the 
microphones which are used to determine a location of the 
audio source (i.e. a direction and a distance to the 
audio source from a predetermined reference point such as 

2 0 the camera) . 

By using an array of microphones 12, audio speaker 
location module 114 provides both tilt and pan 
information with respect to the detected audio source. 
Audio speaker location module 114 also uses this 
25 information to determine the distance (that is, range) to 
the audio source. 

Audio speaker location module 114 also provides a 
pair of normalized cross-correlation values, one for the 
horizontal microphones (that is, the pan microphones) and 

3 0 one for the vertical microphones (that is, the tilt 

microphones) . 

After audio speaker location module 114 determines 
the location of a speaker, speaker validation and framing 
module 116 determines whether the detected speaker should 
35 be validated and how the camera shot for the detected 
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speaker should be framed. Fig. 13 shows a flow chart 
13 00 of the steps taken by speaker validation and framing 
module 116. Briefly, speaker validation and framing 
module 116 first determines, based on a set of criteria, 
5 whether the results from audio speaker location module 
114 (Fig. 4) represent a valid speaker location. The 
criteria for validating a detected speaker are as 
follows : 

a detection from the same location or the vicinity 
10 of the same location is made a predetermined . 

number of times (reference number 132 0 in Fig. 
13) ; 

the pan and tilt values for the location of the 
audio speaker are those supported by camera 14 
15 (reference number 1315 in Fig. 13) ; 

each of the normalized cross -correlation values is 
greater than a corresponding predetermined 
threshold value (reference number 1317 in Fig. 
13) ; and 

20 - the detected audio sequence was determined to have 

been speech (reference number 1318 in Fig. 13) . 
If a detected speaker location is validated, speaker 
validation and framing module 116 then uses a set of 
rules to ascertain an appropriate camera shot. In 

25 determining the appropriate camera shot, speaker 

validation and framing module 116 can use the data stored 
in the detected face (ref 110) files to frame the camera 
shot. Speaker validation and framing module 116 then 
supplies camera control module 80 with appropriate pan, 

30 tilt, and zoom directives. 

The operation of speaker validation and framing 
module 116 will now be described in detail. In step 
1305, speaker validation and framing module 116 first 
determines whether audio speaker location module 114 has 

35 detected an active audio source, which is a speaker for 
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whom audio speaker location module 114 detects the onset 
of speech across a predetermined number of frequencies. 
If no active audio sources has been detected for a 
predetermined period of time, speaker validation and 
5 framing module 116 provides instructions to camera 
positioning device 16 to show a room shot (step 13 07) . 
Speaker validation and framing module 116 can in this 
step use the results of face detection stored in memory 
to frame an appropriate group shot, as will be described 
10 below. 

Speaker validation and framing module 116 
determines whether the detected location corresponds to 
the same location- as the one detected immediately prior 
to the current detection. If not, speaker validation and 

15 framing module 116 deletes the temporary file associated 
with the previous detection (step 1310) . If speaker 
validation and framing module 116 determines that an 
active audio source is detected, it then determines 
whether the detected speaker should be validated based on 

20 the above described criteria (step 1312) . It should be 
noted that the threshold values used to determine whether 
to validate a detection (Ref 1312) can be changed based 
on the results of video based locator 60 stored in the 
detected face files, as described below. If the speaker 

2 5 location is not valid, speaker validation and framing 

module 116 finishes processing. If the speaker location 
is valid, speaker validation and framing module 116 
stores the speaker location in a new temporary file (step 
1322) . Ixx step 132 5 f based on the speaker location in 

30 the temporary file, and on a set of framing rules, 
speaker validation and framing module 116 selects an 
appropriate camera shot. For example, the camera shot 
can frame a single speaker or a group of speakers. A set 
of rules may, for example, indicate that if a speaker is 

35 the dominant speaker based on the number of times he or 
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she has spoken recently, then the camera shot should only 
include him or her. The set of rules can also state that 
if two more or speakers have spoken recently, then the 
camera shot should include all participants in the 
5 conversation taking into account limitations of camera 14 
for the available field of view. Additionally, speaker 
validation and framing module 116 can use the results of 
video based locator 60 to properly frame a camera shot, 
as will be described below. Based on this determination, 
0 speaker validation and framing module 116 provides camera 
control module 80 with camera framing instructions. 

Referring back to Fig. 4, after validating a 
detected speaker, audio location memory module 118" either 
adds the new speaker to an existing speaker file to which 
5 the detected speaker was matched or creates a new speaker 
file. Such speaker files can store the speaker location 
and the number of times the speaker has spoken. 
Additionally, the speaker files are kept in order, with 
most recent speaker being at the top of the order. These 
0 files can be used for framing the camera based on some 
camera framing logic . 

As described previously, audio based locator 70 
first uses the audio data to determine the location of 
the speaker and based on that determination supplies 
5 camera pointing control module 80 with directives as to 
how to move camera 14. Audio based locator 70 can also 
use results of video based locator 60 to appropriately 
frame a camera shot, as will be described in detail 
below. After the camera is moved, video based locator 60 
0 captures frames of video images from camera 14 and 
detects the location of any faces in the video image. 
Camera pointing control module B0 then can use the 
results of both audio and video detection to adjust the 
tilt, pan, and range of camera 14 to correct for any 
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errors in framing the camera, as will be described in 
detail below. 

The manner in which camera control module 80 and 
speaker validation and framing module 116 use the 
5 detection results from video based locator 60 and audio 
based locator 70 to properly frame camera shots will now 
be described in detail . The manner in which camera 
control module 80 uses the face detection results to 
correct errors in camera positioning device 16 will first 

10 be described. Then, the manner in which speaker 

validation and framing module 116 uses the face detection 
results to supplement the results of audio speaker 
detection module 116 to prevent errors in camera" pointing 
directives and to better frame camera shots will be 

15 described. 

In some embodiments, one error for which camera 
control module 80 can correct is the error due to 
misalignment between camera 14 and microphone array 12. 
Generally, audio based locator 70 uses an array of 

20 microphones 12 to determine the location of a speaker 
relative to an audio reference point. The accuracy of 
this determination partly depends on the accuracy of the 
alignment of camera 14 with array of microphones 12 
through camera positioning device 16. However, camera 14 

25 and array of microphones 12 may be misaligned because of 
mistakes during the manufacturing process or as a matter 
of regular use of the system. Therefore, the camera 
pointing directives from audio based locator 70 can 
result in an image in which the speaker is offset from a 

30 desired position on the frame (for example, the center of 
the frame), as shown in Pig. 14. 

Camera control module 80 uses the results of face 
detection from video based locator 60 to correct for the 
offset. Fig. 15 shows a flow chart 1500 of the steps 

35 taken by camera control module 80 to correct for the 
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video offset. If face is not located at a desired 
position in the captured video image (step 1505) , video 
based locator 60 determines that the camera shot is not 
centered on the speaker. Video based locator 60 then 
5 determines which of the detected faces is located closest 
to the desired position in the captured video image and 
assumes that this face corresponds to the detected 
speaker (step 1510) . Video based locator 60 calculates 
the amount by which the closest face is offset from the 

10 desired position. Video based locator 60 then accesses, 
in step 1515, the previously calculated offset values and 
calculates a smoothed offset value, for example, by 
averaging the values (step 1515) . After a predetermined 
number of offset values are used to calculate the 

15 smoothed -of f set value (step 1520), the smoothed offset 
value is used to replace any previously stored smoothed 
offset values and the new value is used from now on to 
correct camera positioning instructions (step 1525) . In - 
some embodiments, video based locator 60 checks from time 

20 to time (for example, every time camera 14 is moved) 

whether the image is offset and recalculates the smoothed 
offset value. 



calculates the offset values for a predetermined number 
25 of frames and then compares them to find a cluster of 

offset values which are close in value to one another. 

Video based locator 60 then calculates an offset value 

based on the cluster of offset values (for example, by 

averaging the values) . In this manner, video based 
3 0 locator 60 filters out those offset values which resulted 

from other factors prior to sending them to camera 

control module 80. 



module 116 can correct for gross pointing errors, which 
3 5 are caused by the results from audio based locator 70 



In some embodiments, video based locator 60 



In some embodiments, audio speaker detection 
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being incorrect for a variety of reasons. For example, 
audio based locator 70 can detect non-speech sounds as 
speech and therefore confuse a non-human acoustic source 
with a human speaker. Additionally, reflection from 
5 large surfaces such as walls and tables can confuse audio 
based locator 70 as to the true source of the audio. In 
these cases, audio based locator 70 may detect the source 
of the audio as the reflection point from the surface 
(for example, a table surface in front of the speaker) . 

10 Additionally, if array of microphones 12 is performing - 
tilt measurements, one tilt measurement microphone may 
receive acoustic waves mainly from the reflection point 
and while another may receive audio "waves - from the 
speaker. This can cause a significant error in the 

15 detected speaker location, resulting in the camera 

pointing below the reflection point or over the head of 
the speaker. Similar problems can occur in the pan 
dimension, although less frequently. In either the case 
of non-speech sources, or reflection, the error is 

20 manifested as a gross camera pointing error where camera 
14 points to the non-speech acoustic source or the source 
of the reflection as shown in Pig. 16. 

Fig. 17 shows a flow chart 1700 of the steps taken 
by audio speaker and validation module 116 to correct for 

25 such gross pointing errors. Audio speaker and validation 
module 116 first determines whether a gross pointing: 
error has occurred. To do so, audio speaker and 
validation module 116 determines whether a detected, face 
is located in an area 1605 in the video frame (Fig. 16) 

30 where the image of the speaker's face is expected (step 
1705) . If a face is not located at a desired position 
(i.e. area 1605) of the captured video image (step 1705), 
video based locator 60 determines that the captured video 
image is not centered. Video based locator 60 then 

35 determines which of the detected faces is located closest 




WO 99/60788 PCT/US99/10667 

- 43 - 

to the desired position in the captured video image and 
assumes that this face corresponds to the detected 
speaker (step 1710) . Video based locator 60 calculates 
the amount by which the closest face is offset from the 
5 desired position. Video based locator 60 then accesses, 
in step 1715, the previously calculated offset values and 
calculates a smoothed offset value, for example, by 
averaging the values (step 1715). After a predetermined 
number of offset values have been used to calculate the 
10 smoothed offset value (step 1720) , the smoothed offset- 
value is used to determine corrective camera instructions 
to compensate for any gross camera pointing errors (step 
172 5) . Camera ^control module 80 then transforms this — 
offset value into camera instructions which are provided 
15 to camera position device 16 (step 1730) . 

In some embodiments, audio speaker and validation 
module 116 can also use the data from video based locator 
60 to correct errors in determining the distance from 
camera 14 to the speaker (that is, range finding errors) . 
20 Generally, range is a difficult dimension for audio 

speaker source location systems to measure accurately. 
The accuracy of the measurement depends on at least two 
factors. The first factor is the size of the microphone 
array 12, where larger arrays yield more accurate 
25 results. The second factor is the duration and quality 
of the audio speech being processed, where longer 
durations and higher utterance counts yield more 
accurate results. Since the range value is used to zoom 
camera 14, errors in the value of the range can .lead to 
3 0 errors in framing the speaker by making a camera shot 
either too tight or too wide, as shown in Fig. 18. 

Fig. 19 shows a flow chart 1900 of the steps taken 
by audio speaker and validation module 116 to correct for 
range finding errors. Audio speaker and validation 
35 module 116 first determines which of the detected faces 
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is located closest to the expected position in the image 
and assumes that this face corresponds to the detected 
speaker (step 1905) . If the size of the closest detected 
face is within a predetermined face size value, then 
5 audio speaker and validation module 116 assumes that the 
range is correct (step 1910) . If not, audio speaker and 
validation module 116 computes a range value which would 
adjust the size of the detected face to fall within the 
predetermined face size threshold value (step 1915) . 
10 Audio speaker and validation module 116 transforms this 
offset value into camera framing directives which are 
supplied to camera 14 and camera positioning device 16 
(step 1920) . 

As stated above, speaker validation and framing 
15 module 116 (Fig. 4) can use the face detection results to 
appropriately frame a camera shot. In some embodiments, 
speaker validation and framing module 116 of audio based 
locator 70 can use the results from video based locator 
60 to dynamically change the variables controlling the 
20 speaker validation process. Speaker validation and 

framing module 116 changes these variables to achieve two 
goals: prevent gross pointing errors and reduce the 
response time of camera 14 and video conferencing system 
10. 

25 Fig. 20 shows a flow chart 2 000 of the steps taken 

by speaker validation and framing module 116 to prevent 
gross pointing errors. Speaker validation and framing 
module 116 first determines whether the location of a . ■ 
previously detected face matches the location of the 

30 detected speaker (step 2005) . If there is a matching 

detected face, then speaker validation and framing module 
116 determines that the detected speaker is a valid 
speaker. However, if there is no matching detected face 
and this is the first detection of this speaker, speaker 

35 validation and framing module 116 decreases the 
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sensitivity of the validation process so that there is 
less likelihood of validating the detected speaker (steps 
2010-2015) . To do so, speaker validation and framing 
module 116 increases three threshold values: the cross- 
5 correlation threshold value (1317 in Fig 13) , the number 
of consecutive detections of a speaker location before 
the speaker location is validated (1320 in Fig. 13), and 
the threshold value for speech detection (1318 in Fig. 
13) . By increasing these threshold values, speaker 
10 validation and framing module 116 reduces the likelihood 
of validating a speaker which does not match a detected 
face . 

If after increasing the threshold values, speaker — 
validation and framing module 116 still validates the 

15 speaker, then speaker validation and framing module 116- 
changes the camera framing rules to mitigate gross 
pointing errors (step 2020) . Speaker validation and 
framing module 116 can change the rules in a number of 
ways: increasing the field of view to include a larger 

20 area, increasing the field of view to include a nearby 
detected face, or defaulting to a group shot which 
includes all detected faces. 

Fig. 21 shows a flow chart 2100 of the steps taken, 
by speaker validation and framing module 116 to reduce 

25 the response time of video conferencing system 10 for 
detecting speakers and pointing the camera. If the 
location of a previously detected face matches the 
location of the detected speaker (step 2105) , then 
speaker validation and framing module 116 increases the 

30 sensitivity of the audio based locator 70 (step 2110) . 
Therefore, the likelihood of detection and validating a 
speaker is increased. To do so, speaker validation and 
framing module 116 performs the following function: 
lowering the correlation threshold value (1317 in Fig. 

35 13) ; lowering the required number of consecutive 
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detections required of a speaker location before the 
speaker location is validated (1320 in Fig. 13) ; and 
lowering speech detection threshold value in audio 
speaker location module 114 in Fig. 4 (1318 in Pig. 13) . 
5 This increases the number of validated detections from 
the speaker in audio based locator 70 and therefore 
results in faster response time. However, increasing the 
sensitivity of the speaker validation process increases 
the number of false positive speaker detections. Since 

10 the audio speaker is already matched against a detected 
face, the false positive detections are easily filtered 
out and therefore do not significantly, if at all, affect 
the performance of video conferencing system 10. 
Additionally, instead of audio range finding, speaker 

15 validation and framing module 116 can use the face 

detection results for range finding, further reducing the 
processing time, the required number of microphones, and 
the required accuracy of microphone mounting, which are 
typically required for performing audio speaker location 

2 0 module 114, 

In some embodiments, speaker validation and 
framing module 116 uses the data from video based locator 
60 to frame shots of all the participants in a meeting. 
Fig. 22 shows a flow chart 2200 of the steps taken by 
25 speaker validation and framing module 116 to frame a 

group shot. Generally, when framing such group shots, 
if speaker validation and framing module 116 only uses 
the results for those speakers detected based on audio 
signals, speaker validation and framing module 116 can 

3 0 only capture those participants who have spoken . 

Therefore, silent participants are left out of the group 
shot. However, by supplementing the audio based detected 
speakers with the data stored in the detected face files, 
speaker validation and framing module 116 can frame the 
35 camera to capture all participants in the group shot. 
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To frame the camera for such a group shot, speaker 
validation and framing module 116 first, determines 
whether the participants have stopped speaking (step 
2205) for a period of time. If so, speaker validation 
5 and framing module 116 uses the detected speaker files 
and the data stored in the detected face files to frame a 
group shot (step 2210) . In some embodiments, speaker 
validation and framing module 116 first uses the detected 
speaker files to frame a group shot and then uses the 

10 data stored in the detected face files to adjust the 

group shot . The group shot preferably includes the most 
recently detected speaker based on audio. The group shot 
also preferably includes as many of the speakers which 
are detected based on the audio signals and as many of 

15 the faces detected based on the video signals as are 
possible given the pan, tilt, and zoom limitations of 
camera 14 and camera positioning device 16. Camera 
control module 80 transforms the adjusted room shot 
values into camera instructions which are provided to 

20 camera positioning device 16 (step 2215) . 

In some embodiments, speaker validation and 
framing module 116 uses the video track files to identify 
a moving speaker and then adjusts the field of view of 
camera 14 to better capture the moving speaker. Figs. 

25 23A, 23B, and 23C show top views of the position of a 
moving speaker 23 00 relative to camera 14 and the field 
of view of camera 14. In Fig. 23A, speaker 2300 is 
stationary relative to camera 14. Camera 14, therefore, 
can capture an image of the speaker with a relatively 

30 narrow field of view 2305. However, referring to Fig. 
23B, as the speaker moves from location A to location B, 
he or she moves out of field of view 2305 and into a 
field of view 2310. As he or she moves back to location 
A, speaker 2300 moves out of field of view 2310 and into 

35 field of view 2310. One method of ensuring that a proper 
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image of the speaker is captured is for camera 14 to use 
a relatively broad field of view 2315. .This has the 
advantage of avoiding continual camera movement to follow 
a moving speaker. Such continual camera movements can 
5 make the video images appear as discontinuous, especially 
when compressed for transmission over a telecommunication 
network . 

Fig. 24 shows a flow chart 2400 of the steps taken 
by speaker validation and framing module 116 to adjust 

10 the field of view of camera 14 for a moving speaker. 
Plow chart 2400 uses the video based tracking detected 
speakers, described in detail above. Generally, as a 
speaker moves, speaker validation and framing module 116 
identifies the speaker as a newly detected speaker. If a 

15 new speaker is not detected, audio speaker validation and 
framing module 116- continues with video based tracking. 
However, if a new speaker location is detected (step 
2405) , speaker validation and framing module 116 checks 
to see if two consecutive speaker locations have been 

2 0 matched to a single track file by video based locator 60 
(step 2410) . If so, the speaker is assumed to be a 
moving speaker. Speaker validation and framing module 
116 sets the camera for tracking a moving speaker by 
increasing the field of view of camera 14 to encompass 

25 both the previous location and the current location of 
the speaker (that is, zoom out camera 14) (step 2415) . 
As long as there are two consecutive matches, camera 14 
will have the broad field of view and video based 
tracking continues (step 2430). However, if thejre are no 

30 consecutive matches, camera 14 is reset and returned to 
its original field of view, (step 2420) . In that case, 
the video based tracking is reset and starts anew (step 
2425) . 

Other embodiments are within the scope of the 
35 following claims. 
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For example, Fig. 25 shows an integrated, portable 
video conferencing system 2500. Video, conferencing 
system 2500 is portable and integrated in a similar 
manner as video conferencing system 10 and can have 
5 similar features, design, and construction as video 

conferencing systems described in the commonly assigned 
U.S. patent application "Integrated Portable 
Videoconferencing," application serial no. 08/694,324, 
filed on November 5, 1997, incorporated in its entirety 

10 by reference. In addition, video conferencing system 
2 500 has substantially similar components as video 
conferencing system 10, except to the extent described 
here. In Fig. 25 components having the same reference 
numeral as those in previous Figs, (such as Fig. 1) have 

15 been previously described and will not be described here. 
It should be "noted that video conferencing system 2500 
also includes a directed microphone array 12', such as 
those described in U.S. serial No. 08/657,63 6, filed May 
30, 1996, and issued as U.S. patent no. 5,715,319, 

20 contents of which are incorporated herein in their 
entirety by reference. 

Video conferencing system 2500 can be operated in 
two modes of operation. In its first mode of operation, 
audio based locator 70 of video conferencing system 10 

25 provides camera positioning directives for panning the 
camera as described above. In this mode of operation, 
video based locator 60 does not perform any functions. 
In some embodiments, this mode of operation is the only 
mode of operation of video conferencing system 2500 and 

30 video based locator 60 is not included in video 
conferencing system 2500. 

In a second mode operation, audio based locator 70 
provides instructions for panning camera 14 while speaker 
validation and framing module 116 uses the data from 

35 video based locator 60 to tilt camera 14 . By processing 
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video signals to provide tilt information, video 
conferencing system 2500 does not require microphones for 
providing tilt information (such as microphones 12C and 
12D in Fig. 1) . Since at least one microphone for tilt 
5 must be offset from the plane in which the pan 
microphones lie, by eliminating the need for tilt 
microphones, video conferencing system 2500 can be 
implemented as a limited dimension system and also be 
designed to be portable. 

10 In video conferencing system 2500, video based - 

locator 60 can use an alternative method of face 
detection in video face location module 102 (Fig. 4), 
which will now be described. Referring to Fig. 4, in 
these embodiments, video face location module 102 detects 

15 the upper contour of moving objects in the video frames, 
which in most cases are humans, using luma values only 
(although in other embodiments chroma values may also be 
used) . Since contour detection is not as computationally 
intensive as the previously described face detection 

20 technique and uses luma values only, it is particularly 
suitable for applications where the underlying system 
does not have significant processing power. This has the 
advantage of enabling designing integrated, portable and 
less expensive video conferencing systems. 

25 Fig. 26 shows a flow chart 2600 of the steps taken 

by video face location module 102 to detect contour of 
speakers using an adaptive contour detection technique. 
In step 2605, after retrieving a new and a previous video 
frame, video face location module 102 first initialize an 

30 adaptive motion detection threshold (MD_THD) by setting 
it to have a minimum initial value (MD_THD_MIN) . The 
adaptive motion detection threshold is used in detecting 
the motion pixels in the captured video frames. Video 
face location module 102 processes current and previous 

35 video frames to detect the motion pixels in the current 
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video frame in order to generate a binary motion map (or 
mask) in a similar manner as described previously in 
reference to flow chart 700 in Fig. 7 (step 2610) . It 
should be noted, however, that here only luma values are 
5 used. 

If the total number of motion pixels in the binary 
motion map is more than a predetermined proportion, here 
one third, of the total number of pixels in the video 
frame (step 2615) , then video face location module 102 

10 determines that the detected motion pixels are due to a 
camera move. If the total number of motion pixels in the 
binary motion map is not more than the predetermined 
proportion of the total number of pixels in the video 
frame (step 2615) , then video face location module 102 

15 determines whether the total number of motion pixels is 
less than a predetermined threshold (MIN_MP_NUM) (step 
2 620) . If so, video face location module 102 determines 
that the number of motion pixels are less than that 
typically expected from a frame having an image of a 

20 moving person. 

However, if video face location module 102 
determines whether the total number of motion pixels is 
not less than a predetermined threshold (MIN_MP_NUM) 
(step 2620) , then video face location module 102 performs 

25 a morphological operation on the binary motion map to 
fill any pixels which are detected to be static but are 
surrounded by motion pixels (step 2625) . The 
morphological operation can, for example, be a 3x3 
operator dilation and erosion operation. . 

30 Video face location module 102 then detects the 

contours of the shapes in the binary motion map (step 
2630) . The contour detection proceeds as follows. In 
each column, from top to bottom, video face location 
module 102 evaluates each moving pixel by looking at the 

35 5x5 pixel block to the lower left or lower right of the 
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pixel. If there are more than 6 moving pixels in either 
block, video face location module 102 identifies the 
pixel as a contour pixel. Since the contours are used 
for providing camera directives for tilting camera 14, 
5 only the upper contours of the detected persons are 

needed. Hence, as soon as video face location module 102 
encounters a contour pixel in a column, video face 
location module 102 finishes analyzing that column. 

Video face location module 102 then calculates the 

10 noise level (step 2635) . The noise level is defined as 
the total number of noise pixels divided by the total 
number of pixels above the detected contours. Noise 
pixels are motion pixels in the binary motion map which 
are above the detected contours, that is, motion pixels 

15 which are assumed not to correspond to any human speaker. 
If the noise level is not below a predetermined noise 
threshold (step 2640) , then it is determined that a less 
sensitive motion detection is to be performed on the 
frame to reject motion pixels detected because of noise. 

20 The motion detection to be performed is less sensitive in 
the sense that the likelihood of detecting motion pixels 
is decreased. To do so, video face location module 102 
increases the adaptive motion detection threshold by a 
predetermined value (step 2645) . If the adaptive motion 

25 detection threshold is more than a maximum allowable 
noise threshold value (step 2650) , then video face 
location module 102 determines that the noise level is 
above a level where reliable contour can be detected. 

If the adaptive motion detection threshold is not 

30 more than the maximum allowable noise threshold value 

(step 2650) , then video face location module 102 performs 
a new motion detection on the motion pixels in the binary 
motion map using the new value of the adaption motion 
detection threshold (step 2655) . This process likely 
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reclassifies some of the motion pixels as non-motion 
pixels. 

At this point steps 2620-2655 are repeated until 
either the maximum allowable noise threshold value is 
5 reached (step 2650) or the detected noise level is below 
the predetermined noise threshold (step 2640) . 

If the noise level is below the predetermined 
threshold (step 2640) , then it is assumed that the noise 
level is sufficiently low that a reliable contour can be 
10 detected. Video face detection module 102 then applies a 
five point median filter to smooth out the contour and to 
further filter out any motion pixels detected due to 
noise (step 2660) - Then, in step 2 665, to reduce the 
amount of stored data, video location module 102 
15 quantizes the detected contours (for example, to 16 
levels) . 

Speaker validation and framing module 116 (Fig, 4) 
then uses this information to determine an appropriate 
tilt angle and supplies camera positioning device 16 with 

20 appropriate directives. To do so, speaker validation and 
framing module 116 selects the highest contour point and 
determines how camera 14 should be tilted so that this 
highest contour point is located at a predetermined 
position in the captured video images. 

25 In some embodiments, other methods of face 

detection such as neural net or color histogram 
distribution based face detection algorithms and 
techniques can be used for determining the location of 
faces of persons in video face location module 1J32 . 

3 0 It should be noted that in the above described 

embodiments, before modifying the camera framing 
directives based on the results of video detection module 
60, camera pointing control 80 or speaker validation and 
framing module 116 first analyzes a predetermined number 

35 of frames. The values for all those frames are then 
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validated to ensure that erroneous corrections are not 
performed. After the results are validated, they can 
then be used to modify the camera framing. In this 
manner, the accuracy of the framing modifications is 
increased. 

What is claimed is: 
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1. A system comprising: 

an image pickup device generating image signals 
representative of an image, 

an audio pickup device generating audio signals 
5 representative of sound from an audio source, and 

an audio source locator processing the image 
signals and audio signals to determine a direction of the 
audio source relative to a reference point. 



2 . The system of claim 1 further comprising an 
10 integrated housing for an integrated video conferencing 

system incorporating the image pickup device, the audio 
pickup device, and the audio source locator. 

3 . The system of claim 1 wherein the integrated 
housing is sized for being portable. 

15 4 . The system of claim 1 wherein the image pickup 

device includes a positioning device for positioning said 
image pickup device, wherein the audio source locator 
supplies control signals to the positioning device for 
positioning the image pickup device, the control signals 

20 being generated based on the determined direction of the 
audio source. 



5 . The system of claim 4 wherein the image pickup 
device is capable of variable zoom and the audio source 
locator supplies control signals to the image pickup 

25 device for varying the zoom of image pickup devipe. 

6 . The system of claim 1 wherein the image 
signals represent frames of video images and the audio 
source is a speaking person, the audio source locator 
detecting an image of the face of the speaking person in 

3 0 one of the frames of video. 
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7. The system of claim 6 wherein the audio source 
locator detects the image of the face of the speaking 
person by detecting the speaking person based on the 
audio signals, detecting images of the faces of a 
5 plurality of persons based on the video signals, and 

correlating the detected images to the speaking person to 
detect the image of the face of the speaking person. 

8 . The system of claim 6 wherein the audio source 
locator determines the direction of the face relative to 
0 the reference point. 

9. The system of claim 6 wherein the audio source 
locator detecting an image of the face of the speaking 
person in. one of the frames of video includes detecting a 
region representing a moving face, 

5 10. The system of claim 6 wherein the audio 

source locator detecting an image of the face of the 
speaking person in one of the frames of video includes 
detecting a region having flesh tone colors in the frames 
of video. 

0 11. The system of claim 10 wherein the audxo ~ 

source locator detecting an image of the face of the 
speaking person in one of the frames of video includes 
determining whether size of the region having flesh tone 
colors corresponds to a pre-selected size, the pre- 

5 selectecTsize representing size of a pre-selected 
standard face. 

12. The system of claim 10 wherein the audio 
source locator detecting an image of the face of the 
speaking person in one of the frames of video includes 
0 determining the region having flesh tone colors does not 
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corresponds to an image of a face, if the region having 
flesh tone colors corresponds to a flesh tone colored 
ob j ect . 

13 , The system of claim 6 wherein the audio 
5 source locator includes: 

an audio based locator determining ah audio based 
direction of the audio source based on the audio signals, 
and 

a video based locator determining a video based 
10 location of an image in one of the frames of video, 

14. The system of claim 13 wherein the audio 
source locator determines the direction based on the 
audio based direction and the video based location of the 
image • 

15 is. The system of claim 14 wherein audio based 

locator determines an offset of the video based location 
of the image from a pre -determined reference point in 
said one of the frames of video and modifying the audio 
based direction, based on the offset, to determine the 

20 direction. 

16. The system of claim 14 further comprising a 
memory unit storing a previously determined offset of a 
video based location of an image in a previous one of the 
frames of video from a pre -determined reference point, 

25 wherein the audio source locator modifies the audio based 
direction, based on the stored offset, to determine the 
direction, 

17. The system of claim 13 wherein the speaking 
person moves relative to the reference point, the audio 

3 0 source locator detecting the movement of the speaker and, 
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in response to the movement, causing an increase in the 
field of view of the image pickup device. 

18. The system of claim 13 wherein the audio 
source locator correlates the audio based direction to a 

5 video based location of the image in one of the frames of 
video and modifies the audio based direction, based on 
the results of said correlation, to determine the 
direction. 

19. The system of claim 13 further comprising a 
10 memory unit for storing a previously determined direction 

of an audio source based on the audio signals and a 
previously determined video based location of an image of 
a face of a non- speaker person in a previous one of the 
frames of video, wherein the audio source locator uses 
15 the stored direction and video based location to cause an 
adjustment in the field of view of the image pickup 
device to include, in the field of view, the audio source 
and previously determined video based location. 



20 



20. The system of claim 13 further comprising: 
a positioning device for positioning said image 

pickup device, wherein the aordi 6" source locator supplies 
control signals to the positioning device for positioning 
the image pickup device, 

the control signals including signals,- -based-on- 
25 the audio based direction, for causing said positioning 
device panning said image pickup device and signals, 
based on the video based location, for tilting said image 
pickup device. 

21. The system of claim 13 wherein the video 
30 based locator determines a video based location of the 
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image by determining, in part or in whole, a contour of 
the image • 

22. The system of claim 21 wherein the video 
based locator uses a parameter in detecting the contour 

5 of the image, wherein changing the parameter in one 

direction increases a likelihood of detecting contours of 
images and changing that parameter in another direction 
decreases the likelihood, and the video based locator 
changes the parameter, when detecting the contour of the 
10 image, to increase or decrease the likelihood. 

23. The system of claim 22 wherein the video 
based locator determines a noise level wherein an 
increase in the noise level decreases the likelihood of 
detecting contours of persons in images, wherein video 

15 based locator changes the parameter based on the noise 
level . 

24. The system of claim 21 wherein the video 
based locator detects a region representing a moving 
person and determines, in part or in whole, a contour of 

20 an image of the moving person. 

25. The system of claim 13 further comprising a 
memory unit for storing a video based location of an 
image in a previous one of the frames of video, 

wherein the audio based locator correlates the 
25 audio based direction of the audio source with the stored 
video based location of the image in the previous one of 
the frames of video to determine whether the image in the 
previous one of the frames of video corresponds to the 
audio source, and 
30 audio based locator uses the audio based direction 

in producing control signals for the image pickup device, 
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only if the audio based locator determines that the image 
in the previous one of the frames of video corresponds to 
the audio source, 

26. The system of claim 13 wherein the audio 
5 based locator detects a plurality of audio sources and 
uses a parameter to determine whether to validate at 
least one of the plurality of audio sources to use in. 
producing control signals for the image pickup device, 
wherein changing the parameter in one direction increases 
10 a likelihood of audio based locator validating said at 
least one of the plurality of audio sources and changing 
that parameter in another direction decreases the 
likelihood, and 

wherein the audio based locator correlates the 
15 audio based direction of the audio source with the stored 
video based location of the image in one of the frames of 
video to determine whether the image in the one of the 
frames of video corresponds to the audio source, and if 
the image in the one of the frames of video corresponds 
to the audio source, the audio based locator changes the 
parameter in the one direction. 



20 



27. The system of claim 26 wherein if the image 
in the one of the frames of video fails to correspond to 
the audio source, the audio based locator changes the: 

25 parameter in the another direction. 

28. The system of claim 13 wherein the audio 
based locator correlates the audio based direction of the 
audio source with the video based location of the image 
in one of the frames of video to determine whether the 

30 image corresponds to the audio source, and 

if the audio based locator determines that the 
image fails to correspond to the audio source, the audio 
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based locator causes an adjustment in the field of view 
of said image pickup device to include,, in the field of 
view, the audio source and the video based location of 
the image in the one of the frames of video. 

29. The system of claim 13 wherein the audio 
source locator further determines a location of the audio 
source relative to the reference point. 

30. The system of claims 29 wherein the location 
is characterized by the direction of the audio source 
relative to the reference point and a distance, 
determined by the audio source locator, from the 
reference point to the audio source. 

31. The system of claim 30 wherein the image 
signals represent frames of video images, 

the audio based locator determines an audio based - 
distance from the reference point to the audio source 
based on the audio signals, 

the video based locator determines a video based 
distance from the reference point to the audio source 
based on an image of the audio source in one of the 
frames of video, and 

the audio source locator determines the distance 
based on the audio based distance and the video based 
distance . 

32. A method comprising the steps of: - 
generating, at an image pickup device, image 

signals representative of an image, 

generating audio signals representative of sound 
from an audio source, and 
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processing the image signals and audio signals to 
determine a direction of the audio source relative to a 
reference point. 



33 . The method of claim 32 further comprising the 
5 step of: 

generating control signals based on the determined 
direction of the audio source, 

positioning the image pickup device, in response 
to the control signals. 

10 34. The method of claim 33 further comprising 

varying a field of view the image pickup device in 
response to the control signals, 

35. The method of claim 32 wherein the image 
signals represent frames of video images, and the audio" 

15 source is a speaking person, the method further 

comprising the step of detecting an image of the face of 
the speaking person in one of the frames of video. 

36. The method of claim 35 wherein detecting the 
image of the face of the speaking person further 

20 comprises the steps of: 

detecting the speaking person based on the audio 
signals, 

detecting images of the faces of a plurality of 
persons based on the video signals, 
25 and correlating the detected images to the 

speaking person to detect the image of the face of the 
speaking person. 



37. The method of claim 35 further comprising the 
step of determining the direction of the face relative to 
3 0 the reference point. 



• 
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38. The method of claim 35 wherein detecting an 



image of the face of the speaking person in one of the 
frames of video includes detecting a region representing 
a moving face. 



image of the face of the speaking person in one of the 
frames of video includes detecting a region having flesh 
tone colors in the frames of video. 



10 image of the face of the speaking person in one of the 
frames of video includes determining whether size of the 
region having flesh tone colors corresponds to a pre- 
selected size, the pre-selected size representing size of 
a pre-selected standard face. . 

15 41. The method of claim 39 wherein detecting an 

image of the face of the speaking person in one of the 
frames of video includes determining the region having 
flesh tone colors does not corresponds to an image of a 
face, if the region having flesh tone colors corresponds 

20 to a flesh tone colored object. 

42. The method of claim 36 wherein processing the 
image signals and audio signals includes: 

determining an audio based direction of the audio 
source based on the audio signals, and 
25 determining a video based location of an. image in 

one of the frames of video. 

43. The method of claim 42 wherein processing the 
image signals and audio signals further includes 
determining the direction based on the audio based 

30 direction and the video based location of the image. 



5 



39. 



The method of claim 35 wherein detecting an 



40. 



The method of claim 39 wherein detecting an 
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44 . The method of claim 42 processing the image 
signals and audio signals further includes 

determining an offset of the video based location 
of the image from a pre -determined reference point in 
5 said one of the frames of video, and 

modifying the audio based direction, based on the 
offset, to determine the direction. 

45. The method of claim 42 wherein processing the 
image signals and audio signals further includes 

10 modifying, based on a previously determined offset of a 
video based location of an image in a previous one of the 
frames of video from a pre -determined reference point, 
the audio based direction to determine the direction. 

46. The method of claim 42 wherein the speaking 
15 person moves relative to the reference point, and wherein 

processing the image signals and audio signals further 
includes: 

detecting the movement of the speaker, and 
causing, in response to the movement, an increase 
20 in the field of view of the image pickup device. 

47. The method of claim 42 wherein processing the 
image signals and audio signals further includes: 

correlating the audio based direction to a video 
based location of an image in one of the frames of video, 
25 and 

modifying the audio based direction, based on the 
results of said correlation, to determine the direction. 

48. The method of claim 42 wherein processing the 
image signals and audio signals further includes using a 

30 previously determined direction of an audio source based 
on the audio signals and a previously determined video 
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based location of an image of a face of a non-speaker 
person in a previous one of the frames ,of video to cause 
an adjustment in the field of view of the image pickup 
device to include, in the field of view, the audio source 
5 and previously determined video based location. 

49. The method of claim 42 further comprising the 
step of supplying control signals, based on the audio 
based direction, for panning said image pickup device and 
signals, based on the video based location, for tilting 

10 said image pickup device. 

50. The method of claim 49 wherein determining a 
video based location of the image includes determining, 
in part or in whole, a contour of the image. 

51. The method of claim 50 wherein a parameter is 
15 used in detecting the contour of the image, wherein 

changing the parameter in one direction increases a 
likelihood of detecting contours of images and changing 
that parameter in another direction decreases the 
likelihood, the method further comprising the step of: 
20 changing the parameter, when detecting the contour 

of the image, to increase or decrease the likelihood. 

52. The method of claim 51 further comprising the 
steps of 

determining a noise level, wherein an increase in 
25 the noise level decreases the likelihood of detecting 
contours of persons in images, and 

changing the parameter based on the noise level. 

53. The method of claim 49 wherein determining a 
video based location of the image includes: 
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detecting a region representing a moving person, 

and 

determining, in part or in whole, a contour of an 
image of the moving person. 

5 54 • The method of claim 42 wherein processing the 

image signals and audio signals further includes: 

correlating the audio based direction of the audio 
source with a video based location of an image in one of 
the frames of video to determine whether the image in the 
10 one of the frames of video corresponds to the audio 
source, and 

using the audio based direction in producing 
control signals for the image pickup device, only if the 
image in the one of the frames of video is determined to 
15 corresponds to the audio source. 

55, The method of claim 42 wherein processing the 
image signals and audio signals further includes: 
detecting a plurality of audio sources, 
using a parameter to determine whether to validate 
at least one of the plurality of audio sources to use in 
producing control signals for the image pickup device, 
wherein changing the parameter in one direction increases 
a likelihood validating said at least one of the 
plurality of audio sources and changing that parameter in 
25 another direction decreases the likelihood, 

correlating the audio based direction of the audio 
source with a video based location of an image in a 
previous one of the frames of video to determine whether 
the image in the previous one of the frames of video 
corresponds to the audio source, and 

changing the parameter in the one direction, if 
the image in the previous one of the frames of video 
corresponds to the audio source. 



20 



30 



WO 99/60788 



PCT/US99/10667 



- 67 - 

56- The method of claim 35 wherein processing the 
image signals and audio signals further, includes: 

correlating the audio based direction of the audio 
source with a video based location of an image in a 
previous one of the frames of video to determine whether 
the image corresponds to the audio source, and 

if the image fails to correspond to the audio 
source, causing an adjustment in the field of view of 
said image pickup device to include, in the field of 
view, the audio source and the video based location of, 
the image in the previous one of the frames of video - 

57. The method of claim 3 5 further comprising 
determining a location of the audio source relative to 
the reference point . 

58. The method of claim 57 wherein the location 
is characterized by the direction of the audio source 
relative to the reference point and a distance, 
determined by the audio source locator, from the 
reference point to the audio source. 

59. The method of claim 58 wherein the image 
signals represent frames of video images, the method 
further comprising: 

determining a audio based distance from the 
reference point to the audio source based on the audio 
signals, 

determining a video based distance from the 
reference point to the audio source based on an image of 
the audio source in one of the frames of video; and 

determining the distance based on the audio based 
distance and the video based distance. 
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60. A system comprising: 

an image pickup device generating image signals 
representative of an image, 

an face detector processing the image signals to 
5 detect a region in the image having flesh tone colors 
and, based on the detection, determining whether the 
image represents a face, 

61. The system of claim 60 wherein the face 
detector determining whether the image represents a face 

10 further includes detecting a region representing a moving 
object . 

62. The system of claim 60 wherein the face 
detector determining whether the image represents a* face 
includes determining whether the region having flesh tone 

15 colors has dimensions corresponding to dimensions of a 
selected image of a selected face. 

63. The system of claim 60 wherein the face 
detector determining whether the image represents a face 
includes determining the region having flesh tone colors 

20 does not correspond to an image of a face, if the region 
having flesh tone colors corresponds to a flesh tone 
colored object. 

64. A method comprising the steps of: 
generating image signals representative of an 

25 image, 

processing the image signals to detect a region in 
the image having flesh tone colors, and 

determining , based on the detection, whether the 
image represents a face. 
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65 . The method of claim 64 wherein the 
determining step further includes detecting a region 
representing a moving object. 

66. The method of claim 64 wherein the 

5 determining step includes determining whether the region 
having flesh tone colors has dimensions corresponding to 
dimensions of a selected image of a selected face. 

67 . The method of claim 64 wherein the 
determining step includes determining the region having 
10 flesh tone colors does not correspond to an image of a 
face, if the region having flesh tone colors corresponds 
to a flesh tone colored object, 

68, A video conferencing system comprising: 
at least two microphones generating audio signals 
15 representative of sound from an audio source, 

a camera generating video signals representative 
of a video image, 

a positioning device for positioning said camera, 
a processor processing the video signals and audio 
20 signals to determine a direction of a speaker relative to 
a reference point and supplying control signals to the 
positioning device for positioning the camera to include 
the speaker in the field of view of the camera, the 
control signals being generated based on the determined 
25 direction of the speaker, and 

a transmitter for transmitting audio and. video 
signals for video-conf erencing. 



69. A system comprising: 

at least two microphones generating audio signals 
3 0 representative of sound from an audio source. 





WO 99/60788 



PCT/US99/I0667 



- 70 - 

a camera generating video signals representative 
of a video image, 



5 determine a direction of a speaker relative to a 

reference point and supplying control signals to the 
positioning device for positioning the camera to include 
the speaker in the field of view of the camera, the 
control signals being generated based on the determined 
10 direction of the speaker, and 

a transmitter for transmitting audio and video 
signals for video-conf erencing. 

70. The system of claim 69 further comprising an 
integrated housing for an integrated video conferencing 
15 system incorporating the microphones, the camera, the 

positioning device, the a processor, and the transmitter. 



housing is sized for being portable. 

72. The system of claim 69 wherein the processor 
20 processes the video signals together with the audio 

signals to determine the direction of the speaker 
relative to the reference point. 

73. The system of claim 72 further comprising an 
integrated housing for an integrated video conferencing 

25 system incorporating the microphones, the camera, the 

positioning device, the a processor, and the transmitter. 



a positioning device for positioning said camera, 
a processor processing the audio signals to 



71. The system of claim 70 wherein the integrated 



74 . The system of claim 73 wherein the integrated 
housing is sized for being portable. 
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6 £ Q else 

b*3 A(i,y) = 0: 

} 
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Binarized image value at location i i 
K (/, j) Current frame pixel luma at location i j 

rjf.fi 

Previous frame pixel luma at location i ! 
f °S" all pixels i. 3 ( 
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Luma pixel at location L j for current frame 

Luma pixel at location I j for previous frame 

Horizontal and vertical index ranges for box n 
s(n) Size (pixel count) for box n 

v t (") Temporal luma difference variance in box n 

*n,{n) Temporal luma difference mean in box n 

Spatial luma variance in box n 

Spatial luma mean in box n Q Q Q 

T s Temporal and spatial thresholds 

$05 * or boxes n { 

<aa-o if v / (/r)<2; 

Remove box(n] from list; 



<33 S 



/-,(«) J 



if v 1 (/i)<z; 

Remove bax(n] from list:; 

} 
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For each video frame^ 0 ( 

processed for face 
detection J 




Do not use for tracking ; 



\3° 




Yes 



Face Location 
Tracking: 
Association 



j Face Location 
Tracking: 
Measurement Update 
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\QOO 

*,(«) Tnck file i horizontal video p„el locarion estimate at frame n 
*\n) Track file i horizontal video frame predicted location estimate at frame n 

x A n ) Track ffle i horizontal video franv mv .i : 

t u., ,deof ™'P«««monon estimate at frame n^ixeb per frame, 

•r, « Track file , horizontal video frame predicted motion estimau: at frame n (p«eis oer ft™ , 
y, M Track file i venica. video frame pLxei iocarioa estimate at rW „ ' ^ 

Mn) Track file i vertical video frame predicted location estimate at frame n 

el) T raC , « V T VidC ° Pre<UCted m0d ° n CStimare " *« » P« frame, 
CjW Track file i confidence at frame n p " 

£■4 Motion prediction decay < 1 .0 
Sea Confidence prediction decay < 1 .0 

f S> for all track files i { 
^) = .r f («-l) + .x(«-l) 

i 5 ,(«) = x(«-i)+.v,(«-0 
AM -0 



lot ^ 

\o3<s 

} 
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sjn) Track file i horizontal pixel search range at frame c CS^.L'O - - c5*"~ ) 
sjn) Track file i vertical pixel search range at frame n / <* \ ^ x I \ 

<T^ T Horizontal position state variance 
(T* y Vertical position state variance 
ct^, Horizontal measurement variance 
O]^ Vertical measurement variance 

x f{ n ) Measurement j horizontal video frame pixel location at frame n 

Measurement j vertical video frame pixel location at frame n 
•xjn) Measurement j horizontal video frame object size at frame n J " .• ---.^ 

W Measurement j vertical video frame object size at frame n ^ " *" 

W oS tax ( ordered track files i) { 

WO 7 if (Track_File(i] .status. tinit — TRUE) { 

\ \ ^ O for { unmatched measurements j ) { 

*\ i^. if ( (k(«)-r>)|<jjn(^w-^>)|< f „.) , { 

' l V3 Mark measurement j as candidate for file i; 

r 

\ V \ if ( candidates j exist ) { 

\ \ XO f or < candidates j of file i ) { 

\M2/2_ ^ «/, = ^(») -.c») 2 +(A(n) - ^(»))' 

\ t X 5 Find minimum d 9 ; 

V \ ^"T* Mark measurement j q 35 oc^aVcA, to file i; 

\ 3 ° Track_File (i] .status, tmeas « TRUE; 

\^ 3^— Track_File(i] . noupdate_count » 0; 

M 33 Track_File(i] .x_meas *x Jm {n) ; 

U 7>7" Track_File(i] .y_meas *y Jm (n) ; 

\ \ H O Track_File Cil .x_size_meas -x, y (/l) ; 

l\ HX- Track_File£i] .y_size_meaa -y v (/l) ; 

} 

MM ,5 else { 

UW> Track_Fileti] .status. traeao - FALSE; 
\\50 Track_Fileti] .noupdate_count +. i ; 
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Track file i 

-r ( -(/i) Track file i 

-t ( (/i) Track file i 

Xj(n) Track tile i 

v,(#i) Track file i 

.V ( (/l) Track file i 

j>i(n ) Track file i 



horizontal video trame pixel locauon estimate at frame n 
i horizontal video trame predicted location estimate at frame n 
i horizontal video frame pixel moaon estimate at frame n (pixels per frame) 
i horizontal video frame predicted morion estimate at frame n (pixels per frame i 
i vertical video frame pixel location estimate at frame n 
i vertical video frame predicted location estimate at frame n 
i vertical video frame pixel motion estimate at frame n (pixels per frame i 
Track file i vertical video frame predicted motion estimate at frame n (pixels per frame) 
x mf (n) Measurement j horizontal video frame pixel location at frame n 
-VWO 1 ) Measurement j vertical video frame pixel location at frame n 
Xtfin) Measurement j horizontal video frame object size at frame n 
y f/ («) Measurement j vertical video frame object size at frame n 
cXn) Track file i confidence at frame n 
Position filter gain 
Motion filter gain 
Confidence filter gain 
Size filter gain 

for ( track files i associated with measurements j ) { 
Track_file[i] .x_p 0 *iY;qis* = ,r.(/i) + g p (x^{n) - .r. (n)) ; 

Track_f ile [i] .y_ pa*iW = y 4 (/i) « + g p (y mi (n) - y.{nj) ; 
Track_file[il .x_motion = x g (n) = .?,(") + gj^^n) - ; 
Track_file[i] ./^motion » y g (n) = + g m (y g (n) - 
Track_file(i] .x_size = x si (n) = x si (n - l) + g $ (x sf (n) - x sg (n - 1)) ; 
Track_file(i] -y.size = y si { {n) = v i( (n - l) + g.^Oi) - y ti {n - l)) ; 

Track_file(i] .confidence « c,(*) = c ( -(n -0 *$<.0 
if (Track_File£iJ .status. tvalid =« FALSE) { 
Track_File (i] .updat e — count +- 1; 

if ( (Track_File[i] . update_count > Minimum valid) 

(Track_File(il -confidence > Minimum valid) ) { 
Track_File [i] .status. tvalid - TRUE;- 



Op 

s; 

Ss 

' 3-\ n 



2 : ~7 



v i- 3 o 



1Z3> for { track files i not associated with measurements ) 
\ ^ Track_f ile (i) ,x_^.\i%cv» x,(n) = i,(n) ; 

\ z Track_f ile Ci] .y_^ c SiW\- ^ ( (n) « v,(/i) ; 

Track_f ile Ci] .x_motion « x ; (/i) = i g (n) ; 
1. U 5 Track_f ile [i] ./^motion = y t {n) = ; 



' 7. 



Track_file[i] .x_size « x w (/t) = x x/ (/t - l) ; 
1 Track_filetiJ .y_size = y si {n) = yjjn - l) ; 

\ 2. 3 ^ Track_f ile fi] .confidence = c,(/i) = c { (n) ; } 




J 
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ACTIVITY DETECTION 






NO ACTIVTTY 






SHOW ROOM DIRECTIVE 






CLEAR AUDIO SPEAKER MEMORY 






ACTIVITY 








2 



35^ 




VALIDATE NEW AUDIO SPEAKER LOCATION RESULTS 
« LEGAL PAN ANCLE 

. LEGAL TTLT ANGLE x „^lA*V^. 
. MINIMUM PAN ^V^«.l,,ft,<OU -ufcCT^*™* 
» MINIMUM TtLT ttri*rf rrtWri** 
0 SPEECH DETECTION 

\ MINIMUM CONSECUTIVE RESULTS FROM SAME LOCATION 



VIDEO FACE LOCATION MEMORY 



AUDIO SPEAKER LOCATION RESULTS 
.PAN. TTLT. RANGE 
t CROSS CORRELATION AMPLITUDES 
. SPEECH DET E CTION 

CURRENT TEMPORARY SINGLE 
. SPEAKER MEMORY 

VIDEO FACE LOCATION MEMORY 



NOT VALID 



VALID 




ADD NEW LOCATION TO MEMORY 



NEW AUDIO SPEAKER LOCATION 
TEMPORARY MEMORY FILE 



RULE BASED CAMERA FRAMING 

. SINGLE SHOT ( DOMINANT SPEAKERS 

. MULTI SHOT (CONVERSATION)? 




EXIT 



AUDIO SPEAKER LOCATION 
MEMORY FILES 



VIDEO FACE LOCATION MEMORY 



CAMERA FRAMING DIRECTIVE 
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Is there ^ <^ 

a detected face centered at a^ * • ^ 

desired position in the 
^ frame? 



No 

X 

Associate the detected ^ 
face closest to the 
desired position 



Access previously 
calculated offsets and 
calculate a smoothed 
offset value 



^5 



Have 
a predetermined 
number of offsets used to 
calculate the 
smoothed 
set value 



NO 



Yas 



Update previously 
stored offset values 
and use the smoothed 1 
offset to correct 
camera positioning 
instructions 



C^5 



End 
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XI 




















\ 



Yl 



L 



EXPECTED FACE 
LOCATION REGION 
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Is there 
a detected face centered at a 
desired position in the 
frame? 



No 



Associate the detected - 
face closest to the 
desired position 



Access previously 
calculated offsets and 
calculate a smoothed 
offset value 



Yea 



Have 
a predetermined 
number of offsets used to 
calculate the 
smoothed 
set value 



Yes 



NO 



Use smootheAoffset to >^ 1"? 
determine corrective 
camera instructions 



z 

Transform offset to 
camera instructions 



.7 V> 
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RANGE MEASURED TOO FAR RANGE .MEASURED TOO CLOSE 

ZOOM <FOV> SETTOO TIGHT ZOOM (FOV) SETTOO WIDE 
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Associate the detected I 
face closest to the 
reference point to 
detected speaker 




Ho 

A 



Calculate the range 
value based on the 
size of the detected 

face and a 
predetermined face 
size threshold. 



Transform the 
corrected range value 
to camera Instructions 



End 
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; Use detected speaker 
! memory and the face 
detection memory to 
v O | create a room shot 



! Transform room shot 
i to appropriate 
instructions for camera 



positioning device 



End 




No 
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SPEAKER MOVES 



\0 



CAMERA MOVES TO 
NEW VIEW 



SPEAKER BACK TO 
ORIGINAL POSITION 



CAMERA VIEW ATTEMPTS TO 
INCLUDE TWO SPEAKERS 
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L\0 y 




YM 



Reset camera field of J 
view i 



Set camera field of 
view for tracking 
motion 



Begin new video based i 
tracking 



30 



Continue video based 
tracking 



End 



J) 



an 



Continue video based 
tracking 
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